Mercurial > emacs
annotate lispref/files.texi @ 66119:bc2d2dc9f534
(compilation-goto-locus): Display the
compilation buffer first and the source buffer second, in case they're
in overlapping frames. Don't raise the compilation frame if it was the
selected window upon entry. Pass the `other-window' arg to
pop-to-buffer.
author | Stefan Monnier <monnier@iro.umontreal.ca> |
---|---|
date | Sun, 16 Oct 2005 14:12:50 +0000 |
parents | 035ea9e34f56 |
children | d14adceeb897 10fe5fadaf89 |
rev | line source |
---|---|
6555 | 1 @c -*-texinfo-*- |
2 @c This is part of the GNU Emacs Lisp Reference Manual. | |
64889
e836425ee789
Update years in copyright notice; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
63583
diff
changeset
|
3 @c Copyright (C) 1990, 1991, 1992, 1993, 1994, 1995, 1998, 1999, 2002, 2003, |
e836425ee789
Update years in copyright notice; nfc.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
63583
diff
changeset
|
4 @c 2004, 2005 Free Software Foundation, Inc. |
6555 | 5 @c See the file elisp.texi for copying conditions. |
6 @setfilename ../info/files | |
7 @node Files, Backups and Auto-Saving, Documentation, Top | |
8 @comment node-name, next, previous, up | |
9 @chapter Files | |
10 | |
11 In Emacs, you can find, create, view, save, and otherwise work with | |
12 files and file directories. This chapter describes most of the | |
13 file-related functions of Emacs Lisp, but a few others are described in | |
14 @ref{Buffers}, and those related to backups and auto-saving are | |
15 described in @ref{Backups and Auto-Saving}. | |
16 | |
7735
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
17 Many of the file functions take one or more arguments that are file |
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
18 names. A file name is actually a string. Most of these functions |
22138
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
19 expand file name arguments by calling @code{expand-file-name}, so that |
7735
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
20 @file{~} is handled correctly, as are relative file names (including |
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
21 @samp{../}). These functions don't recognize environment variable |
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
22 substitutions such as @samp{$HOME}. @xref{File Name Expansion}. |
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
23 |
26696
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
24 When file I/O functions signal Lisp errors, they usually use the |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
25 condition @code{file-error} (@pxref{Handling Errors}). The error |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
26 message is in most cases obtained from the operating system, according |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
27 to locale @code{system-message-locale}, and decoded using coding system |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
28 @code{locale-coding-system} (@pxref{Locales}). |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
29 |
6555 | 30 @menu |
31 * Visiting Files:: Reading files into Emacs buffers for editing. | |
32 * Saving Buffers:: Writing changed buffers back into files. | |
33 * Reading from Files:: Reading files into buffers without visiting. | |
34 * Writing to Files:: Writing new files from parts of buffers. | |
35 * File Locks:: Locking and unlocking files, to prevent | |
36 simultaneous editing by two people. | |
37 * Information about Files:: Testing existence, accessibility, size of files. | |
21007
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
38 * Changing Files:: Renaming files, changing protection, etc. |
6555 | 39 * File Names:: Decomposing and expanding file names. |
40 * Contents of Directories:: Getting a list of the files in a directory. | |
41 * Create/Delete Dirs:: Creating and Deleting Directories. | |
42 * Magic File Names:: Defining "magic" special handling | |
43 for certain file names. | |
12067 | 44 * Format Conversion:: Conversion to and from various file formats. |
6555 | 45 @end menu |
46 | |
47 @node Visiting Files | |
48 @section Visiting Files | |
49 @cindex finding files | |
50 @cindex visiting files | |
51 | |
52 Visiting a file means reading a file into a buffer. Once this is | |
53 done, we say that the buffer is @dfn{visiting} that file, and call the | |
54 file ``the visited file'' of the buffer. | |
55 | |
56 A file and a buffer are two different things. A file is information | |
57 recorded permanently in the computer (unless you delete it). A buffer, | |
58 on the other hand, is information inside of Emacs that will vanish at | |
59 the end of the editing session (or when you kill the buffer). Usually, | |
60 a buffer contains information that you have copied from a file; then we | |
61 say the buffer is visiting that file. The copy in the buffer is what | |
62 you modify with editing commands. Such changes to the buffer do not | |
63 change the file; therefore, to make the changes permanent, you must | |
64 @dfn{save} the buffer, which means copying the altered buffer contents | |
65 back into the file. | |
66 | |
67 In spite of the distinction between files and buffers, people often | |
68 refer to a file when they mean a buffer and vice-versa. Indeed, we say, | |
7735
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
69 ``I am editing a file,'' rather than, ``I am editing a buffer that I |
6555 | 70 will soon save as a file of the same name.'' Humans do not usually need |
71 to make the distinction explicit. When dealing with a computer program, | |
72 however, it is good to keep the distinction in mind. | |
73 | |
74 @menu | |
75 * Visiting Functions:: The usual interface functions for visiting. | |
76 * Subroutines of Visiting:: Lower-level subroutines that they use. | |
77 @end menu | |
78 | |
79 @node Visiting Functions | |
80 @subsection Functions for Visiting Files | |
81 | |
82 This section describes the functions normally used to visit files. | |
83 For historical reasons, these functions have names starting with | |
84 @samp{find-} rather than @samp{visit-}. @xref{Buffer File Name}, for | |
85 functions and variables that access the visited file name of a buffer or | |
86 that find an existing buffer by its visited file name. | |
87 | |
12098 | 88 In a Lisp program, if you want to look at the contents of a file but |
89 not alter it, the fastest way is to use @code{insert-file-contents} in a | |
90 temporary buffer. Visiting the file is not necessary and takes longer. | |
91 @xref{Reading from Files}. | |
92 | |
24951
7451b1458af1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22271
diff
changeset
|
93 @deffn Command find-file filename &optional wildcards |
6555 | 94 This command selects a buffer visiting the file @var{filename}, |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
47980
diff
changeset
|
95 using an existing buffer if there is one, and otherwise creating a |
6555 | 96 new buffer and reading the file into it. It also returns that buffer. |
97 | |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
98 Aside from some technical details, the body of the @code{find-file} |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
99 function is basically equivalent to: |
6555 | 100 |
63583
99e9892a51d9
Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents:
62856
diff
changeset
|
101 @smallexample |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
102 (switch-to-buffer (find-file-noselect filename nil nil wildcards)) |
63583
99e9892a51d9
Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents:
62856
diff
changeset
|
103 @end smallexample |
6555 | 104 |
105 @noindent | |
106 (See @code{switch-to-buffer} in @ref{Displaying Buffers}.) | |
107 | |
24951
7451b1458af1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22271
diff
changeset
|
108 If @var{wildcards} is non-@code{nil}, which is always true in an |
7451b1458af1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22271
diff
changeset
|
109 interactive call, then @code{find-file} expands wildcard characters in |
7451b1458af1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22271
diff
changeset
|
110 @var{filename} and visits all the matching files. |
7451b1458af1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22271
diff
changeset
|
111 |
6555 | 112 When @code{find-file} is called interactively, it prompts for |
113 @var{filename} in the minibuffer. | |
114 @end deffn | |
115 | |
24951
7451b1458af1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22271
diff
changeset
|
116 @defun find-file-noselect filename &optional nowarn rawfile wildcards |
6555 | 117 This function is the guts of all the file-visiting functions. It finds |
118 or creates a buffer visiting the file @var{filename}, and returns it. | |
119 It uses an existing buffer if there is one, and otherwise creates a new | |
120 buffer and reads the file into it. You may make the buffer current or | |
121 display it in a window if you wish, but this function does not do so. | |
122 | |
24952 | 123 If @var{wildcards} is non-@code{nil}, |
124 then @code{find-file-noselect} expands wildcard | |
24951
7451b1458af1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22271
diff
changeset
|
125 characters in @var{filename} and visits all the matching files. |
7451b1458af1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22271
diff
changeset
|
126 |
6555 | 127 When @code{find-file-noselect} uses an existing buffer, it first |
128 verifies that the file has not changed since it was last visited or | |
129 saved in that buffer. If the file has changed, then this function asks | |
130 the user whether to reread the changed file. If the user says | |
131 @samp{yes}, any changes previously made in the buffer are lost. | |
132 | |
21007
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
133 This function displays warning or advisory messages in various peculiar |
21682
90da2489c498
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21007
diff
changeset
|
134 cases, unless the optional argument @var{nowarn} is non-@code{nil}. For |
90da2489c498
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21007
diff
changeset
|
135 example, if it needs to create a buffer, and there is no file named |
25751
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
136 @var{filename}, it displays the message @samp{(New file)} in the echo |
21682
90da2489c498
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21007
diff
changeset
|
137 area, and leaves the buffer empty. |
21007
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
138 |
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
139 The @code{find-file-noselect} function normally calls |
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
140 @code{after-find-file} after reading the file (@pxref{Subroutines of |
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
141 Visiting}). That function sets the buffer major mode, parses local |
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
142 variables, warns the user if there exists an auto-save file more recent |
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
143 than the file just visited, and finishes by running the functions in |
45979
87962bf716e3
*** empty log message ***
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
40188
diff
changeset
|
144 @code{find-file-hook}. |
21007
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
145 |
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
146 If the optional argument @var{rawfile} is non-@code{nil}, then |
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
147 @code{after-find-file} is not called, and the |
45979
87962bf716e3
*** empty log message ***
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
40188
diff
changeset
|
148 @code{find-file-not-found-functions} are not run in case of failure. What's |
21007
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
149 more, a non-@code{nil} @var{rawfile} value suppresses coding system |
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
150 conversion (@pxref{Coding Systems}) and format conversion (@pxref{Format |
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
151 Conversion}). |
6555 | 152 |
32842
b10fc3a9befa
(Visiting Functions): Return value of find-file-noselect may be a list
Kenichi Handa <handa@m17n.org>
parents:
30501
diff
changeset
|
153 The @code{find-file-noselect} function usually returns the buffer that |
b10fc3a9befa
(Visiting Functions): Return value of find-file-noselect may be a list
Kenichi Handa <handa@m17n.org>
parents:
30501
diff
changeset
|
154 is visiting the file @var{filename}. But, if wildcards are actually |
32859
7600e7ac0dcd
(Visiting Functions): Typos.
Gerd Moellmann <gerd@gnu.org>
parents:
32842
diff
changeset
|
155 used and expanded, it returns a list of buffers that are visiting the |
32842
b10fc3a9befa
(Visiting Functions): Return value of find-file-noselect may be a list
Kenichi Handa <handa@m17n.org>
parents:
30501
diff
changeset
|
156 various files. |
6555 | 157 |
158 @example | |
159 @group | |
160 (find-file-noselect "/etc/fstab") | |
161 @result{} #<buffer fstab> | |
162 @end group | |
163 @end example | |
164 @end defun | |
165 | |
24951
7451b1458af1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22271
diff
changeset
|
166 @deffn Command find-file-other-window filename &optional wildcards |
6555 | 167 This command selects a buffer visiting the file @var{filename}, but |
168 does so in a window other than the selected window. It may use another | |
169 existing window or split a window; see @ref{Displaying Buffers}. | |
170 | |
171 When this command is called interactively, it prompts for | |
172 @var{filename}. | |
173 @end deffn | |
174 | |
24951
7451b1458af1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22271
diff
changeset
|
175 @deffn Command find-file-read-only filename &optional wildcards |
6555 | 176 This command selects a buffer visiting the file @var{filename}, like |
177 @code{find-file}, but it marks the buffer as read-only. @xref{Read Only | |
178 Buffers}, for related functions and variables. | |
179 | |
180 When this command is called interactively, it prompts for | |
181 @var{filename}. | |
182 @end deffn | |
183 | |
184 @deffn Command view-file filename | |
22271
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
185 This command visits @var{filename} using View mode, returning to the |
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
186 previous buffer when you exit View mode. View mode is a minor mode that |
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
187 provides commands to skim rapidly through the file, but does not let you |
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
188 modify the text. Entering View mode runs the normal hook |
12098 | 189 @code{view-mode-hook}. @xref{Hooks}. |
6555 | 190 |
191 When @code{view-file} is called interactively, it prompts for | |
192 @var{filename}. | |
193 @end deffn | |
194 | |
24951
7451b1458af1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22271
diff
changeset
|
195 @tindex find-file-wildcards |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
196 @defopt find-file-wildcards |
24951
7451b1458af1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22271
diff
changeset
|
197 If this variable is non-@code{nil}, then the various @code{find-file} |
7451b1458af1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22271
diff
changeset
|
198 commands check for wildcard characters and visit all the files that |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
199 match them (when invoked interactively or when their @var{wildcards} |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
200 argument is non-@code{nil}). If this option is @code{nil}, then |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
201 the @code{find-file} commands ignore their @var{wildcards} argument |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
202 and never treat wildcard characters specially. |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
203 @end defopt |
24951
7451b1458af1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22271
diff
changeset
|
204 |
45979
87962bf716e3
*** empty log message ***
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
40188
diff
changeset
|
205 @defvar find-file-hook |
6555 | 206 The value of this variable is a list of functions to be called after a |
207 file is visited. The file's local-variables specification (if any) will | |
208 have been processed before the hooks are run. The buffer visiting the | |
209 file is current when the hook functions are run. | |
210 | |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
211 This variable is a normal hook. @xref{Hooks}. |
6555 | 212 @end defvar |
213 | |
45979
87962bf716e3
*** empty log message ***
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
40188
diff
changeset
|
214 @defvar find-file-not-found-functions |
6555 | 215 The value of this variable is a list of functions to be called when |
216 @code{find-file} or @code{find-file-noselect} is passed a nonexistent | |
217 file name. @code{find-file-noselect} calls these functions as soon as | |
218 it detects a nonexistent file. It calls them in the order of the list, | |
219 until one of them returns non-@code{nil}. @code{buffer-file-name} is | |
220 already set up. | |
221 | |
222 This is not a normal hook because the values of the functions are | |
21007
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
223 used, and in many cases only some of the functions are called. |
6555 | 224 @end defvar |
225 | |
226 @node Subroutines of Visiting | |
227 @comment node-name, next, previous, up | |
228 @subsection Subroutines of Visiting | |
229 | |
22138
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
230 The @code{find-file-noselect} function uses two important subroutines |
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
231 which are sometimes useful in user Lisp code: @code{create-file-buffer} |
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
232 and @code{after-find-file}. This section explains how to use them. |
6555 | 233 |
234 @defun create-file-buffer filename | |
235 This function creates a suitably named buffer for visiting | |
236 @var{filename}, and returns it. It uses @var{filename} (sans directory) | |
237 as the name if that name is free; otherwise, it appends a string such as | |
238 @samp{<2>} to get an unused name. See also @ref{Creating Buffers}. | |
239 | |
240 @strong{Please note:} @code{create-file-buffer} does @emph{not} | |
241 associate the new buffer with a file and does not select the buffer. | |
12098 | 242 It also does not use the default major mode. |
6555 | 243 |
244 @example | |
245 @group | |
246 (create-file-buffer "foo") | |
247 @result{} #<buffer foo> | |
248 @end group | |
249 @group | |
250 (create-file-buffer "foo") | |
251 @result{} #<buffer foo<2>> | |
252 @end group | |
253 @group | |
254 (create-file-buffer "foo") | |
255 @result{} #<buffer foo<3>> | |
256 @end group | |
257 @end example | |
258 | |
259 This function is used by @code{find-file-noselect}. | |
260 It uses @code{generate-new-buffer} (@pxref{Creating Buffers}). | |
261 @end defun | |
262 | |
26696
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
263 @defun after-find-file &optional error warn noauto after-find-file-from-revert-buffer nomodes |
6555 | 264 This function sets the buffer major mode, and parses local variables |
265 (@pxref{Auto Major Mode}). It is called by @code{find-file-noselect} | |
266 and by the default revert function (@pxref{Reverting}). | |
267 | |
268 @cindex new file message | |
269 @cindex file open error | |
270 If reading the file got an error because the file does not exist, but | |
271 its directory does exist, the caller should pass a non-@code{nil} value | |
272 for @var{error}. In that case, @code{after-find-file} issues a warning: | |
25751
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
273 @samp{(New file)}. For more serious errors, the caller should usually not |
6555 | 274 call @code{after-find-file}. |
275 | |
276 If @var{warn} is non-@code{nil}, then this function issues a warning | |
277 if an auto-save file exists and is more recent than the visited file. | |
278 | |
26696
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
279 If @var{noauto} is non-@code{nil}, that says not to enable or disable |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
280 Auto-Save mode. The mode remains enabled if it was enabled before. |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
281 |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
282 If @var{after-find-file-from-revert-buffer} is non-@code{nil}, that |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
283 means this call was from @code{revert-buffer}. This has no direct |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
284 effect, but some mode functions and hook functions check the value |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
285 of this variable. |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
286 |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
287 If @var{nomodes} is non-@code{nil}, that means don't alter the buffer's |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
288 major mode, don't process local variables specifications in the file, |
45979
87962bf716e3
*** empty log message ***
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
40188
diff
changeset
|
289 and don't run @code{find-file-hook}. This feature is used by |
26696
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
290 @code{revert-buffer} in some cases. |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
291 |
6555 | 292 The last thing @code{after-find-file} does is call all the functions |
45979
87962bf716e3
*** empty log message ***
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
40188
diff
changeset
|
293 in the list @code{find-file-hook}. |
6555 | 294 @end defun |
295 | |
296 @node Saving Buffers | |
297 @section Saving Buffers | |
298 | |
299 When you edit a file in Emacs, you are actually working on a buffer | |
300 that is visiting that file---that is, the contents of the file are | |
301 copied into the buffer and the copy is what you edit. Changes to the | |
302 buffer do not change the file until you @dfn{save} the buffer, which | |
303 means copying the contents of the buffer into the file. | |
304 | |
305 @deffn Command save-buffer &optional backup-option | |
306 This function saves the contents of the current buffer in its visited | |
307 file if the buffer has been modified since it was last visited or saved. | |
308 Otherwise it does nothing. | |
309 | |
310 @code{save-buffer} is responsible for making backup files. Normally, | |
311 @var{backup-option} is @code{nil}, and @code{save-buffer} makes a backup | |
7735
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
312 file only if this is the first save since visiting the file. Other |
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
313 values for @var{backup-option} request the making of backup files in |
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
314 other circumstances: |
6555 | 315 |
316 @itemize @bullet | |
317 @item | |
318 With an argument of 4 or 64, reflecting 1 or 3 @kbd{C-u}'s, the | |
319 @code{save-buffer} function marks this version of the file to be | |
320 backed up when the buffer is next saved. | |
321 | |
322 @item | |
323 With an argument of 16 or 64, reflecting 2 or 3 @kbd{C-u}'s, the | |
324 @code{save-buffer} function unconditionally backs up the previous | |
325 version of the file before saving it. | |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
326 |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
327 @item |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
328 With an argument of 0, unconditionally do @emph{not} make any backup file. |
6555 | 329 @end itemize |
330 @end deffn | |
331 | |
56215 | 332 @deffn Command save-some-buffers &optional save-silently-p pred |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
333 @anchor{Definition of save-some-buffers} |
6555 | 334 This command saves some modified file-visiting buffers. Normally it |
335 asks the user about each buffer. But if @var{save-silently-p} is | |
336 non-@code{nil}, it saves all the file-visiting buffers without querying | |
337 the user. | |
338 | |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
339 The optional @var{pred} argument controls which buffers to ask about |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
340 (or to save silently if @var{save-silently-p} is non-@code{nil}). |
26770
2d8554ed8748
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
26696
diff
changeset
|
341 If it is @code{nil}, that means to ask only about file-visiting buffers. |
2d8554ed8748
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
26696
diff
changeset
|
342 If it is @code{t}, that means also offer to save certain other non-file |
2d8554ed8748
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
26696
diff
changeset
|
343 buffers---those that have a non-@code{nil} buffer-local value of |
65369
822218f80ae4
2005-09-08 Chong Yidong <cyd@stupidchicken.com>
Chong Yidong <cyd@stupidchicken.com>
parents:
65248
diff
changeset
|
344 @code{buffer-offer-save} (@pxref{Killing Buffers}). A user who says |
822218f80ae4
2005-09-08 Chong Yidong <cyd@stupidchicken.com>
Chong Yidong <cyd@stupidchicken.com>
parents:
65248
diff
changeset
|
345 @samp{yes} to saving a non-file buffer is asked to specify the file |
65437
035ea9e34f56
2005-09-10 Chong Yidong <cyd@stupidchicken.com>
Chong Yidong <cyd@stupidchicken.com>
parents:
65369
diff
changeset
|
346 name to use. The @code{save-buffers-kill-emacs} function passes the |
65369
822218f80ae4
2005-09-08 Chong Yidong <cyd@stupidchicken.com>
Chong Yidong <cyd@stupidchicken.com>
parents:
65248
diff
changeset
|
347 value @code{t} for @var{pred}. |
26770
2d8554ed8748
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
26696
diff
changeset
|
348 |
2d8554ed8748
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
26696
diff
changeset
|
349 If @var{pred} is neither @code{t} nor @code{nil}, then it should be |
2d8554ed8748
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
26696
diff
changeset
|
350 a function of no arguments. It will be called in each buffer to decide |
2d8554ed8748
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
26696
diff
changeset
|
351 whether to offer to save that buffer. If it returns a non-@code{nil} |
2d8554ed8748
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
26696
diff
changeset
|
352 value in a certain buffer, that means do offer to save that buffer. |
6555 | 353 @end deffn |
354 | |
56215 | 355 @deffn Command write-file filename &optional confirm |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
356 @anchor{Definition of write-file} |
6555 | 357 This function writes the current buffer into file @var{filename}, makes |
358 the buffer visit that file, and marks it not modified. Then it renames | |
359 the buffer based on @var{filename}, appending a string like @samp{<2>} | |
360 if necessary to make a unique buffer name. It does most of this work by | |
21682
90da2489c498
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21007
diff
changeset
|
361 calling @code{set-visited-file-name} (@pxref{Buffer File Name}) and |
90da2489c498
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21007
diff
changeset
|
362 @code{save-buffer}. |
26696
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
363 |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
364 If @var{confirm} is non-@code{nil}, that means to ask for confirmation |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
365 before overwriting an existing file. Interactively, confirmation is |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
366 required, unless the user supplies a prefix argument. |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
367 |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
368 If @var{filename} is an existing directory, or a symbolic link to one, |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
369 @code{write-file} uses the name of the visited file, in directory |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
370 @var{filename}. If the buffer is not visiting a file, it uses the |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
371 buffer name instead. |
6555 | 372 @end deffn |
373 | |
15913
f415fdc67ad3
Add xrefs from Saving Buffers to Format Conversion and Saving
Richard M. Stallman <rms@gnu.org>
parents:
15765
diff
changeset
|
374 Saving a buffer runs several hooks. It also performs format |
f415fdc67ad3
Add xrefs from Saving Buffers to Format Conversion and Saving
Richard M. Stallman <rms@gnu.org>
parents:
15765
diff
changeset
|
375 conversion (@pxref{Format Conversion}), and may save text properties in |
f415fdc67ad3
Add xrefs from Saving Buffers to Format Conversion and Saving
Richard M. Stallman <rms@gnu.org>
parents:
15765
diff
changeset
|
376 ``annotations'' (@pxref{Saving Properties}). |
f415fdc67ad3
Add xrefs from Saving Buffers to Format Conversion and Saving
Richard M. Stallman <rms@gnu.org>
parents:
15765
diff
changeset
|
377 |
45979
87962bf716e3
*** empty log message ***
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
40188
diff
changeset
|
378 @defvar write-file-functions |
6555 | 379 The value of this variable is a list of functions to be called before |
380 writing out a buffer to its visited file. If one of them returns | |
381 non-@code{nil}, the file is considered already written and the rest of | |
382 the functions are not called, nor is the usual code for writing the file | |
383 executed. | |
384 | |
45979
87962bf716e3
*** empty log message ***
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
40188
diff
changeset
|
385 If a function in @code{write-file-functions} returns non-@code{nil}, it |
6555 | 386 is responsible for making a backup file (if that is appropriate). |
387 To do so, execute the following code: | |
388 | |
389 @example | |
390 (or buffer-backed-up (backup-buffer)) | |
391 @end example | |
392 | |
393 You might wish to save the file modes value returned by | |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
394 @code{backup-buffer} and use that (if non-@code{nil}) to set the mode |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
395 bits of the file that you write. This is what @code{save-buffer} |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
396 normally does. @xref{Making Backups,, Making Backup Files}. |
6555 | 397 |
45979
87962bf716e3
*** empty log message ***
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
40188
diff
changeset
|
398 The hook functions in @code{write-file-functions} are also responsible for |
22138
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
399 encoding the data (if desired): they must choose a suitable coding |
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
400 system (@pxref{Lisp and Coding Systems}), perform the encoding |
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
401 (@pxref{Explicit Encoding}), and set @code{last-coding-system-used} to |
22271
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
402 the coding system that was used (@pxref{Encoding and I/O}). |
22138
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
403 |
45979
87962bf716e3
*** empty log message ***
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
40188
diff
changeset
|
404 If you set this hook locally in a buffer, it is assumed to be |
87962bf716e3
*** empty log message ***
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
40188
diff
changeset
|
405 associated with the file or the way the contents of the buffer were |
87962bf716e3
*** empty log message ***
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
40188
diff
changeset
|
406 obtained. Thus the variable is marked as a permanent local, so that |
87962bf716e3
*** empty log message ***
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
40188
diff
changeset
|
407 changing the major mode does not alter a buffer-local value. On the |
87962bf716e3
*** empty log message ***
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
40188
diff
changeset
|
408 other hand, calling @code{set-visited-file-name} will reset it. |
87962bf716e3
*** empty log message ***
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
40188
diff
changeset
|
409 If this is not what you want, you might like to use |
87962bf716e3
*** empty log message ***
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
40188
diff
changeset
|
410 @code{write-contents-functions} instead. |
21007
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
411 |
6555 | 412 Even though this is not a normal hook, you can use @code{add-hook} and |
413 @code{remove-hook} to manipulate the list. @xref{Hooks}. | |
414 @end defvar | |
415 | |
416 @c Emacs 19 feature | |
45979
87962bf716e3
*** empty log message ***
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
40188
diff
changeset
|
417 @defvar write-contents-functions |
56322
f597c982349e
(Saving Buffers): Cleanup write-contents-function.
Richard M. Stallman <rms@gnu.org>
parents:
56321
diff
changeset
|
418 This works just like @code{write-file-functions}, but it is intended |
f597c982349e
(Saving Buffers): Cleanup write-contents-function.
Richard M. Stallman <rms@gnu.org>
parents:
56321
diff
changeset
|
419 for hooks that pertain to the buffer's contents, not to the particular |
f597c982349e
(Saving Buffers): Cleanup write-contents-function.
Richard M. Stallman <rms@gnu.org>
parents:
56321
diff
changeset
|
420 visited file or its location. Such hooks are usually set up by major |
f597c982349e
(Saving Buffers): Cleanup write-contents-function.
Richard M. Stallman <rms@gnu.org>
parents:
56321
diff
changeset
|
421 modes, as buffer-local bindings for this variable. This variable |
f597c982349e
(Saving Buffers): Cleanup write-contents-function.
Richard M. Stallman <rms@gnu.org>
parents:
56321
diff
changeset
|
422 automatically becomes buffer-local whenever it is set; switching to a |
f597c982349e
(Saving Buffers): Cleanup write-contents-function.
Richard M. Stallman <rms@gnu.org>
parents:
56321
diff
changeset
|
423 new major mode always resets this variable, but calling |
f597c982349e
(Saving Buffers): Cleanup write-contents-function.
Richard M. Stallman <rms@gnu.org>
parents:
56321
diff
changeset
|
424 @code{set-visited-file-name} does not. |
f597c982349e
(Saving Buffers): Cleanup write-contents-function.
Richard M. Stallman <rms@gnu.org>
parents:
56321
diff
changeset
|
425 |
f597c982349e
(Saving Buffers): Cleanup write-contents-function.
Richard M. Stallman <rms@gnu.org>
parents:
56321
diff
changeset
|
426 If any of the functions in this hook returns non-@code{nil}, the file |
f597c982349e
(Saving Buffers): Cleanup write-contents-function.
Richard M. Stallman <rms@gnu.org>
parents:
56321
diff
changeset
|
427 is considered already written and the rest are not called and neither |
f597c982349e
(Saving Buffers): Cleanup write-contents-function.
Richard M. Stallman <rms@gnu.org>
parents:
56321
diff
changeset
|
428 are the functions in @code{write-file-functions}. |
6555 | 429 @end defvar |
430 | |
53531
5bd5de5e98c2
(Saving Buffers): Clarify descriptions of `write-contents-functions'
Luc Teirlinck <teirllm@auburn.edu>
parents:
53505
diff
changeset
|
431 @defopt before-save-hook |
5bd5de5e98c2
(Saving Buffers): Clarify descriptions of `write-contents-functions'
Luc Teirlinck <teirllm@auburn.edu>
parents:
53505
diff
changeset
|
432 This normal hook runs before a buffer is saved in its visited file, |
5bd5de5e98c2
(Saving Buffers): Clarify descriptions of `write-contents-functions'
Luc Teirlinck <teirllm@auburn.edu>
parents:
53505
diff
changeset
|
433 regardless of whether that is done normally or by one of the hooks |
53575
a679a0134e06
*** empty log message ***
Luc Teirlinck <teirllm@auburn.edu>
parents:
53531
diff
changeset
|
434 described above. For instance, the @file{copyright.el} program uses |
a679a0134e06
*** empty log message ***
Luc Teirlinck <teirllm@auburn.edu>
parents:
53531
diff
changeset
|
435 this hook to make sure the file you are saving has the current year in |
a679a0134e06
*** empty log message ***
Luc Teirlinck <teirllm@auburn.edu>
parents:
53531
diff
changeset
|
436 its copyright notice. |
53531
5bd5de5e98c2
(Saving Buffers): Clarify descriptions of `write-contents-functions'
Luc Teirlinck <teirllm@auburn.edu>
parents:
53505
diff
changeset
|
437 @end defopt |
53505
780b9eb8b58e
hooks.texi (Standard Hooks): Add before-save-hook.
Simon Josefsson <jas@extundo.com>
parents:
53425
diff
changeset
|
438 |
6555 | 439 @c Emacs 19 feature |
53531
5bd5de5e98c2
(Saving Buffers): Clarify descriptions of `write-contents-functions'
Luc Teirlinck <teirllm@auburn.edu>
parents:
53505
diff
changeset
|
440 @defopt after-save-hook |
6555 | 441 This normal hook runs after a buffer has been saved in its visited file. |
22271
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
442 One use of this hook is in Fast Lock mode; it uses this hook to save the |
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
443 highlighting information in a cache file. |
53531
5bd5de5e98c2
(Saving Buffers): Clarify descriptions of `write-contents-functions'
Luc Teirlinck <teirllm@auburn.edu>
parents:
53505
diff
changeset
|
444 @end defopt |
6555 | 445 |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
446 @defopt file-precious-flag |
6555 | 447 If this variable is non-@code{nil}, then @code{save-buffer} protects |
448 against I/O errors while saving by writing the new file to a temporary | |
449 name instead of the name it is supposed to have, and then renaming it to | |
450 the intended name after it is clear there are no errors. This procedure | |
451 prevents problems such as a lack of disk space from resulting in an | |
452 invalid file. | |
453 | |
12226 | 454 As a side effect, backups are necessarily made by copying. @xref{Rename |
455 or Copy}. Yet, at the same time, saving a precious file always breaks | |
456 all hard links between the file you save and other file names. | |
6555 | 457 |
22271
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
458 Some modes give this variable a non-@code{nil} buffer-local value |
21682
90da2489c498
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21007
diff
changeset
|
459 in particular buffers. |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
460 @end defopt |
6555 | 461 |
462 @defopt require-final-newline | |
463 This variable determines whether files may be written out that do | |
464 @emph{not} end with a newline. If the value of the variable is | |
465 @code{t}, then @code{save-buffer} silently adds a newline at the end of | |
466 the file whenever the buffer being saved does not already end in one. | |
467 If the value of the variable is non-@code{nil}, but not @code{t}, then | |
468 @code{save-buffer} asks the user whether to add a newline each time the | |
469 case arises. | |
470 | |
471 If the value of the variable is @code{nil}, then @code{save-buffer} | |
472 doesn't add newlines at all. @code{nil} is the default value, but a few | |
473 major modes set it to @code{t} in particular buffers. | |
474 @end defopt | |
475 | |
21682
90da2489c498
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21007
diff
changeset
|
476 See also the function @code{set-visited-file-name} (@pxref{Buffer File |
90da2489c498
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21007
diff
changeset
|
477 Name}). |
15765
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
478 |
6555 | 479 @node Reading from Files |
480 @comment node-name, next, previous, up | |
481 @section Reading from Files | |
482 | |
483 You can copy a file from the disk and insert it into a buffer | |
484 using the @code{insert-file-contents} function. Don't use the user-level | |
485 command @code{insert-file} in a Lisp program, as that sets the mark. | |
486 | |
487 @defun insert-file-contents filename &optional visit beg end replace | |
488 This function inserts the contents of file @var{filename} into the | |
12226 | 489 current buffer after point. It returns a list of the absolute file name |
6555 | 490 and the length of the data inserted. An error is signaled if |
491 @var{filename} is not the name of a file that can be read. | |
492 | |
12098 | 493 The function @code{insert-file-contents} checks the file contents |
494 against the defined file formats, and converts the file contents if | |
495 appropriate. @xref{Format Conversion}. It also calls the functions in | |
496 the list @code{after-insert-file-functions}; see @ref{Saving | |
25751
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
497 Properties}. Normally, one of the functions in the |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
498 @code{after-insert-file-functions} list determines the coding system |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
499 (@pxref{Coding Systems}) used for decoding the file's contents. |
6555 | 500 |
501 If @var{visit} is non-@code{nil}, this function additionally marks the | |
502 buffer as unmodified and sets up various fields in the buffer so that it | |
503 is visiting the file @var{filename}: these include the buffer's visited | |
504 file name and its last save file modtime. This feature is used by | |
505 @code{find-file-noselect} and you probably should not use it yourself. | |
506 | |
507 If @var{beg} and @var{end} are non-@code{nil}, they should be integers | |
508 specifying the portion of the file to insert. In this case, @var{visit} | |
509 must be @code{nil}. For example, | |
510 | |
511 @example | |
512 (insert-file-contents filename nil 0 500) | |
513 @end example | |
514 | |
515 @noindent | |
516 inserts the first 500 characters of a file. | |
517 | |
518 If the argument @var{replace} is non-@code{nil}, it means to replace the | |
519 contents of the buffer (actually, just the accessible portion) with the | |
520 contents of the file. This is better than simply deleting the buffer | |
521 contents and inserting the whole file, because (1) it preserves some | |
522 marker positions and (2) it puts less data in the undo list. | |
21007
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
523 |
22138
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
524 It is possible to read a special file (such as a FIFO or an I/O device) |
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
525 with @code{insert-file-contents}, as long as @var{replace} and |
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
526 @var{visit} are @code{nil}. |
21007
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
527 @end defun |
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
528 |
22138
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
529 @defun insert-file-contents-literally filename &optional visit beg end replace |
21007
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
530 This function works like @code{insert-file-contents} except that it does |
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
531 not do format decoding (@pxref{Format Conversion}), does not do |
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
532 character code conversion (@pxref{Coding Systems}), does not run |
45979
87962bf716e3
*** empty log message ***
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
40188
diff
changeset
|
533 @code{find-file-hook}, does not perform automatic uncompression, and so |
21007
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
534 on. |
6555 | 535 @end defun |
536 | |
537 If you want to pass a file name to another process so that another | |
538 program can read the file, use the function @code{file-local-copy}; see | |
539 @ref{Magic File Names}. | |
540 | |
541 @node Writing to Files | |
542 @comment node-name, next, previous, up | |
543 @section Writing to Files | |
544 | |
545 You can write the contents of a buffer, or part of a buffer, directly | |
546 to a file on disk using the @code{append-to-file} and | |
547 @code{write-region} functions. Don't use these functions to write to | |
548 files that are being visited; that could cause confusion in the | |
549 mechanisms for visiting. | |
550 | |
551 @deffn Command append-to-file start end filename | |
552 This function appends the contents of the region delimited by | |
553 @var{start} and @var{end} in the current buffer to the end of file | |
554 @var{filename}. If that file does not exist, it is created. This | |
555 function returns @code{nil}. | |
556 | |
557 An error is signaled if @var{filename} specifies a nonwritable file, | |
558 or a nonexistent file in a directory where files cannot be created. | |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
559 |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
560 When called from Lisp, this function is completely equivalent to: |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
561 |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
562 @example |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
563 (write-region start end filename t) |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
564 @end example |
6555 | 565 @end deffn |
566 | |
26696
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
567 @deffn Command write-region start end filename &optional append visit lockname mustbenew |
6555 | 568 This function writes the region delimited by @var{start} and @var{end} |
569 in the current buffer into the file specified by @var{filename}. | |
570 | |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
571 If @var{start} is @code{nil}, then the command writes the entire buffer |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
572 contents (@emph{not} just the accessible portion) to the file and |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
573 ignores @var{end}. |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
574 |
6555 | 575 @c Emacs 19 feature |
576 If @var{start} is a string, then @code{write-region} writes or appends | |
25751
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
577 that string, rather than text from the buffer. @var{end} is ignored in |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
578 this case. |
6555 | 579 |
580 If @var{append} is non-@code{nil}, then the specified text is appended | |
60444
78a2cd972ba1
(Writing to Files): Get rid of "Emacs 21".
Richard M. Stallman <rms@gnu.org>
parents:
59877
diff
changeset
|
581 to the existing file contents (if any). If @var{append} is an |
78a2cd972ba1
(Writing to Files): Get rid of "Emacs 21".
Richard M. Stallman <rms@gnu.org>
parents:
59877
diff
changeset
|
582 integer, @code{write-region} seeks to that byte offset from the start |
78a2cd972ba1
(Writing to Files): Get rid of "Emacs 21".
Richard M. Stallman <rms@gnu.org>
parents:
59877
diff
changeset
|
583 of the file and writes the data from there. |
6555 | 584 |
25751
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
585 If @var{mustbenew} is non-@code{nil}, then @code{write-region} asks |
60444
78a2cd972ba1
(Writing to Files): Get rid of "Emacs 21".
Richard M. Stallman <rms@gnu.org>
parents:
59877
diff
changeset
|
586 for confirmation if @var{filename} names an existing file. If |
78a2cd972ba1
(Writing to Files): Get rid of "Emacs 21".
Richard M. Stallman <rms@gnu.org>
parents:
59877
diff
changeset
|
587 @var{mustbenew} is the symbol @code{excl}, then @code{write-region} |
78a2cd972ba1
(Writing to Files): Get rid of "Emacs 21".
Richard M. Stallman <rms@gnu.org>
parents:
59877
diff
changeset
|
588 does not ask for confirmation, but instead it signals an error |
78a2cd972ba1
(Writing to Files): Get rid of "Emacs 21".
Richard M. Stallman <rms@gnu.org>
parents:
59877
diff
changeset
|
589 @code{file-already-exists} if the file already exists. |
25751
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
590 |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
591 The test for an existing file, when @var{mustbenew} is @code{excl}, uses |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
592 a special system feature. At least for files on a local disk, there is |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
593 no chance that some other program could create a file of the same name |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
594 before Emacs does, without Emacs's noticing. |
22138
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
595 |
6555 | 596 If @var{visit} is @code{t}, then Emacs establishes an association |
597 between the buffer and the file: the buffer is then visiting that file. | |
598 It also sets the last file modification time for the current buffer to | |
599 @var{filename}'s modtime, and marks the buffer as not modified. This | |
600 feature is used by @code{save-buffer}, but you probably should not use | |
601 it yourself. | |
602 | |
603 @c Emacs 19 feature | |
604 If @var{visit} is a string, it specifies the file name to visit. This | |
605 way, you can write the data to one file (@var{filename}) while recording | |
606 the buffer as visiting another file (@var{visit}). The argument | |
607 @var{visit} is used in the echo area message and also for file locking; | |
608 @var{visit} is stored in @code{buffer-file-name}. This feature is used | |
609 to implement @code{file-precious-flag}; don't use it yourself unless you | |
610 really know what you're doing. | |
611 | |
26696
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
612 The optional argument @var{lockname}, if non-@code{nil}, specifies the |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
613 file name to use for purposes of locking and unlocking, overriding |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
614 @var{filename} and @var{visit} for that purpose. |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
615 |
12098 | 616 The function @code{write-region} converts the data which it writes to |
617 the appropriate file formats specified by @code{buffer-file-format}. | |
618 @xref{Format Conversion}. It also calls the functions in the list | |
619 @code{write-region-annotate-functions}; see @ref{Saving Properties}. | |
6555 | 620 |
22271
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
621 Normally, @code{write-region} displays the message @samp{Wrote |
6555 | 622 @var{filename}} in the echo area. If @var{visit} is neither @code{t} |
623 nor @code{nil} nor a string, then this message is inhibited. This | |
624 feature is useful for programs that use files for internal purposes, | |
7735
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
625 files that the user does not need to know about. |
6555 | 626 @end deffn |
627 | |
56215 | 628 @defmac with-temp-file file body... |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
629 @anchor{Definition of with-temp-file} |
21682
90da2489c498
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21007
diff
changeset
|
630 The @code{with-temp-file} macro evaluates the @var{body} forms with a |
90da2489c498
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21007
diff
changeset
|
631 temporary buffer as the current buffer; then, at the end, it writes the |
90da2489c498
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21007
diff
changeset
|
632 buffer contents into file @var{file}. It kills the temporary buffer |
90da2489c498
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21007
diff
changeset
|
633 when finished, restoring the buffer that was current before the |
90da2489c498
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21007
diff
changeset
|
634 @code{with-temp-file} form. Then it returns the value of the last form |
90da2489c498
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21007
diff
changeset
|
635 in @var{body}. |
21007
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
636 |
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
637 The current buffer is restored even in case of an abnormal exit via |
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
638 @code{throw} or error (@pxref{Nonlocal Exits}). |
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
639 |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
640 See also @code{with-temp-buffer} in @ref{Definition of |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
641 with-temp-buffer,, The Current Buffer}. |
21007
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
642 @end defmac |
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
643 |
6555 | 644 @node File Locks |
645 @section File Locks | |
646 @cindex file locks | |
647 | |
59877
36a927615e6d
(File Locks): Not supported on MS systems.
Richard M. Stallman <rms@gnu.org>
parents:
56981
diff
changeset
|
648 When two users edit the same file at the same time, they are likely |
36a927615e6d
(File Locks): Not supported on MS systems.
Richard M. Stallman <rms@gnu.org>
parents:
56981
diff
changeset
|
649 to interfere with each other. Emacs tries to prevent this situation |
36a927615e6d
(File Locks): Not supported on MS systems.
Richard M. Stallman <rms@gnu.org>
parents:
56981
diff
changeset
|
650 from arising by recording a @dfn{file lock} when a file is being |
36a927615e6d
(File Locks): Not supported on MS systems.
Richard M. Stallman <rms@gnu.org>
parents:
56981
diff
changeset
|
651 modified. (File locks are not implemented on Microsoft systems.) |
6555 | 652 Emacs can then detect the first attempt to modify a buffer visiting a |
653 file that is locked by another Emacs job, and ask the user what to do. | |
24951
7451b1458af1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22271
diff
changeset
|
654 The file lock is really a file, a symbolic link with a special name, |
7451b1458af1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22271
diff
changeset
|
655 stored in the same directory as the file you are editing. |
6555 | 656 |
24951
7451b1458af1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22271
diff
changeset
|
657 When you access files using NFS, there may be a small probability that |
7451b1458af1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22271
diff
changeset
|
658 you and another user will both lock the same file ``simultaneously''. |
7451b1458af1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22271
diff
changeset
|
659 If this happens, it is possible for the two users to make changes |
7451b1458af1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22271
diff
changeset
|
660 simultaneously, but Emacs will still warn the user who saves second. |
7451b1458af1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22271
diff
changeset
|
661 Also, the detection of modification of a buffer visiting a file changed |
7451b1458af1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22271
diff
changeset
|
662 on disk catches some cases of simultaneous editing; see |
7451b1458af1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22271
diff
changeset
|
663 @ref{Modification Time}. |
6555 | 664 |
665 @defun file-locked-p filename | |
22271
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
666 This function returns @code{nil} if the file @var{filename} is not |
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
667 locked. It returns @code{t} if it is locked by this Emacs process, and |
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
668 it returns the name of the user who has locked it if it is locked by |
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
669 some other job. |
6555 | 670 |
671 @example | |
672 @group | |
673 (file-locked-p "foo") | |
674 @result{} nil | |
675 @end group | |
676 @end example | |
677 @end defun | |
678 | |
679 @defun lock-buffer &optional filename | |
24951
7451b1458af1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22271
diff
changeset
|
680 This function locks the file @var{filename}, if the current buffer is |
6555 | 681 modified. The argument @var{filename} defaults to the current buffer's |
682 visited file. Nothing is done if the current buffer is not visiting a | |
59877
36a927615e6d
(File Locks): Not supported on MS systems.
Richard M. Stallman <rms@gnu.org>
parents:
56981
diff
changeset
|
683 file, or is not modified, or if the system does not support locking. |
6555 | 684 @end defun |
685 | |
686 @defun unlock-buffer | |
687 This function unlocks the file being visited in the current buffer, | |
688 if the buffer is modified. If the buffer is not modified, then | |
689 the file should not be locked, so this function does nothing. It also | |
59877
36a927615e6d
(File Locks): Not supported on MS systems.
Richard M. Stallman <rms@gnu.org>
parents:
56981
diff
changeset
|
690 does nothing if the current buffer is not visiting a file, or if the |
36a927615e6d
(File Locks): Not supported on MS systems.
Richard M. Stallman <rms@gnu.org>
parents:
56981
diff
changeset
|
691 system does not support locking. |
6555 | 692 @end defun |
693 | |
25751
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
694 File locking is not supported on some systems. On systems that do not |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
695 support it, the functions @code{lock-buffer}, @code{unlock-buffer} and |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
696 @code{file-locked-p} do nothing and return @code{nil}. |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
697 |
6555 | 698 @defun ask-user-about-lock file other-user |
699 This function is called when the user tries to modify @var{file}, but it | |
21007
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
700 is locked by another user named @var{other-user}. The default |
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
701 definition of this function asks the user to say what to do. The value |
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
702 this function returns determines what Emacs does next: |
6555 | 703 |
704 @itemize @bullet | |
705 @item | |
706 A value of @code{t} says to grab the lock on the file. Then | |
707 this user may edit the file and @var{other-user} loses the lock. | |
708 | |
709 @item | |
710 A value of @code{nil} says to ignore the lock and let this | |
711 user edit the file anyway. | |
712 | |
713 @item | |
714 @kindex file-locked | |
715 This function may instead signal a @code{file-locked} error, in which | |
716 case the change that the user was about to make does not take place. | |
717 | |
718 The error message for this error looks like this: | |
719 | |
720 @example | |
721 @error{} File is locked: @var{file} @var{other-user} | |
722 @end example | |
723 | |
724 @noindent | |
725 where @code{file} is the name of the file and @var{other-user} is the | |
726 name of the user who has locked the file. | |
727 @end itemize | |
728 | |
21007
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
729 If you wish, you can replace the @code{ask-user-about-lock} function |
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
730 with your own version that makes the decision in another way. The code |
6555 | 731 for its usual definition is in @file{userlock.el}. |
732 @end defun | |
733 | |
734 @node Information about Files | |
735 @section Information about Files | |
736 | |
7735
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
737 The functions described in this section all operate on strings that |
62585
78962e585d20
(Locating Files): New subsection. Describe locate-file and executable-find.
Eli Zaretskii <eliz@gnu.org>
parents:
61949
diff
changeset
|
738 designate file names. With a few exceptions, all the functions have |
78962e585d20
(Locating Files): New subsection. Describe locate-file and executable-find.
Eli Zaretskii <eliz@gnu.org>
parents:
61949
diff
changeset
|
739 names that begin with the word @samp{file}. These functions all |
78962e585d20
(Locating Files): New subsection. Describe locate-file and executable-find.
Eli Zaretskii <eliz@gnu.org>
parents:
61949
diff
changeset
|
740 return information about actual files or directories, so their |
78962e585d20
(Locating Files): New subsection. Describe locate-file and executable-find.
Eli Zaretskii <eliz@gnu.org>
parents:
61949
diff
changeset
|
741 arguments must all exist as actual files or directories unless |
78962e585d20
(Locating Files): New subsection. Describe locate-file and executable-find.
Eli Zaretskii <eliz@gnu.org>
parents:
61949
diff
changeset
|
742 otherwise noted. |
6555 | 743 |
744 @menu | |
745 * Testing Accessibility:: Is a given file readable? Writable? | |
746 * Kinds of Files:: Is it a directory? A symbolic link? | |
747 * Truenames:: Eliminating symbolic links from a file name. | |
748 * File Attributes:: How large is it? Any other names? Etc. | |
62585
78962e585d20
(Locating Files): New subsection. Describe locate-file and executable-find.
Eli Zaretskii <eliz@gnu.org>
parents:
61949
diff
changeset
|
749 * Locating Files:: How to find a file in standard places. |
6555 | 750 @end menu |
751 | |
752 @node Testing Accessibility | |
753 @comment node-name, next, previous, up | |
754 @subsection Testing Accessibility | |
755 @cindex accessibility of a file | |
756 @cindex file accessibility | |
757 | |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
758 These functions test for permission to access a file in specific |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
759 ways. Unless explicitly stated otherwise, they recursively follow |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
760 symbolic links for their file name arguments, at all levels (at the |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
761 level of the file itself and at all levels of parent directories). |
6555 | 762 |
763 @defun file-exists-p filename | |
51654
24b62b8f3def
Fix minor Texinfo usage.
Richard M. Stallman <rms@gnu.org>
parents:
51558
diff
changeset
|
764 This function returns @code{t} if a file named @var{filename} appears |
24b62b8f3def
Fix minor Texinfo usage.
Richard M. Stallman <rms@gnu.org>
parents:
51558
diff
changeset
|
765 to exist. This does not mean you can necessarily read the file, only |
24b62b8f3def
Fix minor Texinfo usage.
Richard M. Stallman <rms@gnu.org>
parents:
51558
diff
changeset
|
766 that you can find out its attributes. (On Unix and GNU/Linux, this is |
24b62b8f3def
Fix minor Texinfo usage.
Richard M. Stallman <rms@gnu.org>
parents:
51558
diff
changeset
|
767 true if the file exists and you have execute permission on the |
24b62b8f3def
Fix minor Texinfo usage.
Richard M. Stallman <rms@gnu.org>
parents:
51558
diff
changeset
|
768 containing directories, regardless of the protection of the file |
24b62b8f3def
Fix minor Texinfo usage.
Richard M. Stallman <rms@gnu.org>
parents:
51558
diff
changeset
|
769 itself.) |
6555 | 770 |
771 If the file does not exist, or if fascist access control policies | |
772 prevent you from finding the attributes of the file, this function | |
773 returns @code{nil}. | |
51654
24b62b8f3def
Fix minor Texinfo usage.
Richard M. Stallman <rms@gnu.org>
parents:
51558
diff
changeset
|
774 |
24b62b8f3def
Fix minor Texinfo usage.
Richard M. Stallman <rms@gnu.org>
parents:
51558
diff
changeset
|
775 Directories are files, so @code{file-exists-p} returns @code{t} when |
24b62b8f3def
Fix minor Texinfo usage.
Richard M. Stallman <rms@gnu.org>
parents:
51558
diff
changeset
|
776 given a directory name. However, symbolic links are treated |
24b62b8f3def
Fix minor Texinfo usage.
Richard M. Stallman <rms@gnu.org>
parents:
51558
diff
changeset
|
777 specially; @code{file-exists-p} returns @code{t} for a symbolic link |
24b62b8f3def
Fix minor Texinfo usage.
Richard M. Stallman <rms@gnu.org>
parents:
51558
diff
changeset
|
778 name only if the target file exists. |
6555 | 779 @end defun |
780 | |
781 @defun file-readable-p filename | |
782 This function returns @code{t} if a file named @var{filename} exists | |
783 and you can read it. It returns @code{nil} otherwise. | |
784 | |
785 @example | |
786 @group | |
787 (file-readable-p "files.texi") | |
788 @result{} t | |
789 @end group | |
790 @group | |
791 (file-exists-p "/usr/spool/mqueue") | |
792 @result{} t | |
793 @end group | |
794 @group | |
795 (file-readable-p "/usr/spool/mqueue") | |
796 @result{} nil | |
797 @end group | |
798 @end example | |
799 @end defun | |
800 | |
801 @c Emacs 19 feature | |
802 @defun file-executable-p filename | |
803 This function returns @code{t} if a file named @var{filename} exists and | |
26696
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
804 you can execute it. It returns @code{nil} otherwise. On Unix and |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
805 GNU/Linux, if the file is a directory, execute permission means you can |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
806 check the existence and attributes of files inside the directory, and |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
807 open those files if their modes permit. |
6555 | 808 @end defun |
809 | |
810 @defun file-writable-p filename | |
7735
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
811 This function returns @code{t} if the file @var{filename} can be written |
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
812 or created by you, and @code{nil} otherwise. A file is writable if the |
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
813 file exists and you can write it. It is creatable if it does not exist, |
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
814 but the specified directory does exist and you can write in that |
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
815 directory. |
6555 | 816 |
817 In the third example below, @file{foo} is not writable because the | |
818 parent directory does not exist, even though the user could create such | |
819 a directory. | |
820 | |
821 @example | |
822 @group | |
823 (file-writable-p "~/foo") | |
824 @result{} t | |
825 @end group | |
826 @group | |
827 (file-writable-p "/foo") | |
828 @result{} nil | |
829 @end group | |
830 @group | |
831 (file-writable-p "~/no-such-dir/foo") | |
832 @result{} nil | |
833 @end group | |
834 @end example | |
835 @end defun | |
836 | |
837 @c Emacs 19 feature | |
838 @defun file-accessible-directory-p dirname | |
839 This function returns @code{t} if you have permission to open existing | |
59877
36a927615e6d
(File Locks): Not supported on MS systems.
Richard M. Stallman <rms@gnu.org>
parents:
56981
diff
changeset
|
840 files in the directory whose name as a file is @var{dirname}; |
36a927615e6d
(File Locks): Not supported on MS systems.
Richard M. Stallman <rms@gnu.org>
parents:
56981
diff
changeset
|
841 otherwise (or if there is no such directory), it returns @code{nil}. |
36a927615e6d
(File Locks): Not supported on MS systems.
Richard M. Stallman <rms@gnu.org>
parents:
56981
diff
changeset
|
842 The value of @var{dirname} may be either a directory name (such as |
36a927615e6d
(File Locks): Not supported on MS systems.
Richard M. Stallman <rms@gnu.org>
parents:
56981
diff
changeset
|
843 @file{/foo/}) or the file name of a file which is a directory |
36a927615e6d
(File Locks): Not supported on MS systems.
Richard M. Stallman <rms@gnu.org>
parents:
56981
diff
changeset
|
844 (such as @file{/foo}, without the final slash). |
6555 | 845 |
846 Example: after the following, | |
847 | |
848 @example | |
849 (file-accessible-directory-p "/foo") | |
850 @result{} nil | |
851 @end example | |
852 | |
853 @noindent | |
854 we can deduce that any attempt to read a file in @file{/foo/} will | |
855 give an error. | |
856 @end defun | |
857 | |
22138
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
858 @defun access-file filename string |
21007
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
859 This function opens file @var{filename} for reading, then closes it and |
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
860 returns @code{nil}. However, if the open fails, it signals an error |
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
861 using @var{string} as the error message text. |
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
862 @end defun |
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
863 |
12067 | 864 @defun file-ownership-preserved-p filename |
865 This function returns @code{t} if deleting the file @var{filename} and | |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
866 then creating it anew would keep the file's owner unchanged. It also |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
867 returns @code{t} for nonexistent files. |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
868 |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
869 If @var{filename} is a symbolic link, then, unlike the other functions |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
870 discussed here, @code{file-ownership-preserved-p} does @emph{not} |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
871 replace @var{filename} with its target. However, it does recursively |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
872 follow symbolic links at all levels of parent directories. |
12067 | 873 @end defun |
874 | |
6555 | 875 @defun file-newer-than-file-p filename1 filename2 |
876 @cindex file age | |
877 @cindex file modification time | |
7735
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
878 This function returns @code{t} if the file @var{filename1} is |
6555 | 879 newer than file @var{filename2}. If @var{filename1} does not |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
880 exist, it returns @code{nil}. If @var{filename1} does exist, but |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
881 @var{filename2} does not, it returns @code{t}. |
6555 | 882 |
7735
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
883 In the following example, assume that the file @file{aug-19} was written |
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
884 on the 19th, @file{aug-20} was written on the 20th, and the file |
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
885 @file{no-file} doesn't exist at all. |
6555 | 886 |
887 @example | |
888 @group | |
889 (file-newer-than-file-p "aug-19" "aug-20") | |
890 @result{} nil | |
891 @end group | |
892 @group | |
893 (file-newer-than-file-p "aug-20" "aug-19") | |
894 @result{} t | |
895 @end group | |
896 @group | |
897 (file-newer-than-file-p "aug-19" "no-file") | |
898 @result{} t | |
899 @end group | |
900 @group | |
901 (file-newer-than-file-p "no-file" "aug-19") | |
902 @result{} nil | |
903 @end group | |
904 @end example | |
905 | |
906 You can use @code{file-attributes} to get a file's last modification | |
907 time as a list of two numbers. @xref{File Attributes}. | |
908 @end defun | |
909 | |
910 @node Kinds of Files | |
911 @comment node-name, next, previous, up | |
912 @subsection Distinguishing Kinds of Files | |
913 | |
12098 | 914 This section describes how to distinguish various kinds of files, such |
915 as directories, symbolic links, and ordinary files. | |
6555 | 916 |
917 @defun file-symlink-p filename | |
918 @cindex file symbolic links | |
50501
3bf63c244c44
(Kinds of Files): Correct return value of file-symlink-p.
Richard M. Stallman <rms@gnu.org>
parents:
49600
diff
changeset
|
919 If the file @var{filename} is a symbolic link, the |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
920 @code{file-symlink-p} function returns the (non-recursive) link target |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
921 as a string. (Determining the file name that the link points to from |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
922 the target is nontrivial.) First, this function recursively follows |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
923 symbolic links at all levels of parent directories. |
6555 | 924 |
925 If the file @var{filename} is not a symbolic link (or there is no such file), | |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
47980
diff
changeset
|
926 @code{file-symlink-p} returns @code{nil}. |
6555 | 927 |
928 @example | |
929 @group | |
930 (file-symlink-p "foo") | |
931 @result{} nil | |
932 @end group | |
933 @group | |
934 (file-symlink-p "sym-link") | |
935 @result{} "foo" | |
936 @end group | |
937 @group | |
938 (file-symlink-p "sym-link2") | |
939 @result{} "sym-link" | |
940 @end group | |
941 @group | |
942 (file-symlink-p "/bin") | |
943 @result{} "/pub/bin" | |
944 @end group | |
945 @end example | |
946 | |
947 @c !!! file-symlink-p: should show output of ls -l for comparison | |
948 @end defun | |
949 | |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
950 The next two functions recursively follow symbolic links at |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
951 all levels for @var{filename}. |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
952 |
6555 | 953 @defun file-directory-p filename |
954 This function returns @code{t} if @var{filename} is the name of an | |
955 existing directory, @code{nil} otherwise. | |
956 | |
957 @example | |
958 @group | |
959 (file-directory-p "~rms") | |
960 @result{} t | |
961 @end group | |
962 @group | |
963 (file-directory-p "~rms/lewis/files.texi") | |
964 @result{} nil | |
965 @end group | |
966 @group | |
967 (file-directory-p "~rms/lewis/no-such-file") | |
968 @result{} nil | |
969 @end group | |
970 @group | |
971 (file-directory-p "$HOME") | |
972 @result{} nil | |
973 @end group | |
974 @group | |
975 (file-directory-p | |
976 (substitute-in-file-name "$HOME")) | |
977 @result{} t | |
978 @end group | |
979 @end example | |
980 @end defun | |
981 | |
12067 | 982 @defun file-regular-p filename |
983 This function returns @code{t} if the file @var{filename} exists and is | |
24951
7451b1458af1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22271
diff
changeset
|
984 a regular file (not a directory, named pipe, terminal, or |
12067 | 985 other I/O device). |
986 @end defun | |
987 | |
6555 | 988 @node Truenames |
989 @subsection Truenames | |
990 @cindex truename (of file) | |
991 | |
992 @c Emacs 19 features | |
993 The @dfn{truename} of a file is the name that you get by following | |
26696
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
994 symbolic links at all levels until none remain, then simplifying away |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
995 @samp{.}@: and @samp{..}@: appearing as name components. This results |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
996 in a sort of canonical name for the file. A file does not always have a |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
997 unique truename; the number of distinct truenames a file has is equal to |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
998 the number of hard links to the file. However, truenames are useful |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
999 because they eliminate symbolic links as a cause of name variation. |
6555 | 1000 |
1001 @defun file-truename filename | |
26696
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
1002 The function @code{file-truename} returns the truename of the file |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
1003 @var{filename}. The argument must be an absolute file name. |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1004 |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1005 This function does not expand environment variables. Only |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1006 @code{substitute-in-file-name} does that. @xref{Definition of |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1007 substitute-in-file-name}. |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1008 |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1009 If you may need to follow symbolic links preceding @samp{..}@: |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1010 appearing as a name component, you should make sure to call |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1011 @code{file-truename} without prior direct or indirect calls to |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1012 @code{expand-file-name}, as otherwise the file name component |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1013 immediately preceding @samp{..} will be ``simplified away'' before |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1014 @code{file-truename} is called. To eliminate the need for a call to |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1015 @code{expand-file-name}, @code{file-truename} handles @samp{~} in the |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1016 same way that @code{expand-file-name} does. @xref{File Name |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1017 Expansion,, Functions that Expand Filenames}. |
26696
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
1018 @end defun |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
1019 |
52003
0509fad02151
(Truenames): Add LIMIT arg to file-chase-links.
Richard M. Stallman <rms@gnu.org>
parents:
51913
diff
changeset
|
1020 @defun file-chase-links filename &optional limit |
26696
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
1021 This function follows symbolic links, starting with @var{filename}, |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
1022 until it finds a file name which is not the name of a symbolic link. |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1023 Then it returns that file name. This function does @emph{not} follow |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1024 symbolic links at the level of parent directories. |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1025 |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1026 If you specify a number for @var{limit}, then after chasing through |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1027 that many links, the function just returns what it has even if that is |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1028 still a symbolic link. |
6555 | 1029 @end defun |
1030 | |
26696
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
1031 To illustrate the difference between @code{file-chase-links} and |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
1032 @code{file-truename}, suppose that @file{/usr/foo} is a symbolic link to |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
1033 the directory @file{/home/foo}, and @file{/home/foo/hello} is an |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
1034 ordinary file (or at least, not a symbolic link) or nonexistent. Then |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
1035 we would have: |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
1036 |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
1037 @example |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
1038 (file-chase-links "/usr/foo/hello") |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
1039 ;; @r{This does not follow the links in the parent directories.} |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
1040 @result{} "/usr/foo/hello" |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
1041 (file-truename "/usr/foo/hello") |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
1042 ;; @r{Assuming that @file{/home} is not a symbolic link.} |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
1043 @result{} "/home/foo/hello" |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
1044 @end example |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
1045 |
6555 | 1046 @xref{Buffer File Name}, for related information. |
1047 | |
1048 @node File Attributes | |
1049 @comment node-name, next, previous, up | |
1050 @subsection Other Information about Files | |
1051 | |
1052 This section describes the functions for getting detailed information | |
1053 about a file, other than its contents. This information includes the | |
1054 mode bits that control access permission, the owner and group numbers, | |
1055 the number of names, the inode number, the size, and the times of access | |
1056 and modification. | |
1057 | |
1058 @defun file-modes filename | |
1059 @cindex permission | |
1060 @cindex file attributes | |
1061 This function returns the mode bits of @var{filename}, as an integer. | |
1062 The mode bits are also called the file permissions, and they specify | |
1063 access control in the usual Unix fashion. If the low-order bit is 1, | |
7735
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
1064 then the file is executable by all users, if the second-lowest-order bit |
6555 | 1065 is 1, then the file is writable by all users, etc. |
1066 | |
1067 The highest value returnable is 4095 (7777 octal), meaning that | |
52978
1a5c50faf357
Replace @sc{foo} with @acronym{FOO}.
Eli Zaretskii <eliz@gnu.org>
parents:
52401
diff
changeset
|
1068 everyone has read, write, and execute permission, that the @acronym{SUID} bit |
6555 | 1069 is set for both others and group, and that the sticky bit is set. |
1070 | |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1071 If @var{filename} does not exist, @code{file-modes} returns @code{nil}. |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1072 |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1073 This function recursively follows symbolic links at all levels. |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1074 |
6555 | 1075 @example |
1076 @group | |
1077 (file-modes "~/junk/diffs") | |
1078 @result{} 492 ; @r{Decimal integer.} | |
1079 @end group | |
1080 @group | |
1081 (format "%o" 492) | |
1082 @result{} "754" ; @r{Convert to octal.} | |
1083 @end group | |
1084 | |
1085 @group | |
1086 (set-file-modes "~/junk/diffs" 438) | |
1087 @result{} nil | |
1088 @end group | |
1089 | |
1090 @group | |
1091 (format "%o" 438) | |
1092 @result{} "666" ; @r{Convert to octal.} | |
1093 @end group | |
1094 | |
1095 @group | |
1096 % ls -l diffs | |
1097 -rw-rw-rw- 1 lewis 0 3063 Oct 30 16:00 diffs | |
1098 @end group | |
1099 @end example | |
1100 @end defun | |
1101 | |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1102 If the @var{filename} argument to the next two functions is a symbolic |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1103 link, then these function do @emph{not} replace it with its target. |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1104 However, they both recursively follow symbolic links at all levels of |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1105 parent directories. |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1106 |
6555 | 1107 @defun file-nlinks filename |
1108 This functions returns the number of names (i.e., hard links) that | |
1109 file @var{filename} has. If the file does not exist, then this function | |
1110 returns @code{nil}. Note that symbolic links have no effect on this | |
1111 function, because they are not considered to be names of the files they | |
1112 link to. | |
1113 | |
1114 @example | |
1115 @group | |
1116 % ls -l foo* | |
1117 -rw-rw-rw- 2 rms 4 Aug 19 01:27 foo | |
1118 -rw-rw-rw- 2 rms 4 Aug 19 01:27 foo1 | |
1119 @end group | |
1120 | |
1121 @group | |
1122 (file-nlinks "foo") | |
1123 @result{} 2 | |
1124 @end group | |
1125 @group | |
1126 (file-nlinks "doesnt-exist") | |
1127 @result{} nil | |
1128 @end group | |
1129 @end example | |
1130 @end defun | |
1131 | |
56215 | 1132 @defun file-attributes filename &optional id-format |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1133 @anchor{Definition of file-attributes} |
6555 | 1134 This function returns a list of attributes of file @var{filename}. If |
1135 the specified file cannot be opened, it returns @code{nil}. | |
53109
420dc7ac8867
(File Attributes): Describe new parameter ID-FORMAT.
Lars Hansen <larsh@soem.dk>
parents:
52978
diff
changeset
|
1136 The optional parameter @var{id-format} specifies the preferred format |
420dc7ac8867
(File Attributes): Describe new parameter ID-FORMAT.
Lars Hansen <larsh@soem.dk>
parents:
52978
diff
changeset
|
1137 of attributes @acronym{UID} and @acronym{GID} (see below)---the |
420dc7ac8867
(File Attributes): Describe new parameter ID-FORMAT.
Lars Hansen <larsh@soem.dk>
parents:
52978
diff
changeset
|
1138 valid values are @code{'string} and @code{'integer}. The latter is |
420dc7ac8867
(File Attributes): Describe new parameter ID-FORMAT.
Lars Hansen <larsh@soem.dk>
parents:
52978
diff
changeset
|
1139 the default, but we plan to change that, so you should specify a |
420dc7ac8867
(File Attributes): Describe new parameter ID-FORMAT.
Lars Hansen <larsh@soem.dk>
parents:
52978
diff
changeset
|
1140 non-@code{nil} value for @var{id-format} if you use the returned |
420dc7ac8867
(File Attributes): Describe new parameter ID-FORMAT.
Lars Hansen <larsh@soem.dk>
parents:
52978
diff
changeset
|
1141 @acronym{UID} or @acronym{GID}. |
6555 | 1142 |
1143 The elements of the list, in order, are: | |
1144 | |
1145 @enumerate 0 | |
1146 @item | |
1147 @code{t} for a directory, a string for a symbolic link (the name | |
1148 linked to), or @code{nil} for a text file. | |
1149 | |
1150 @c Wordy so as to prevent an overfull hbox. --rjc 15mar92 | |
1151 @item | |
1152 The number of names the file has. Alternate names, also known as hard | |
1153 links, can be created by using the @code{add-name-to-file} function | |
21007
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
1154 (@pxref{Changing Files}). |
6555 | 1155 |
1156 @item | |
53109
420dc7ac8867
(File Attributes): Describe new parameter ID-FORMAT.
Lars Hansen <larsh@soem.dk>
parents:
52978
diff
changeset
|
1157 The file's @acronym{UID} as a string or an integer. If a string |
420dc7ac8867
(File Attributes): Describe new parameter ID-FORMAT.
Lars Hansen <larsh@soem.dk>
parents:
52978
diff
changeset
|
1158 value cannot be looked up, the integer value is returned. |
6555 | 1159 |
1160 @item | |
53109
420dc7ac8867
(File Attributes): Describe new parameter ID-FORMAT.
Lars Hansen <larsh@soem.dk>
parents:
52978
diff
changeset
|
1161 The file's @acronym{GID} likewise. |
6555 | 1162 |
1163 @item | |
1164 The time of last access, as a list of two integers. | |
1165 The first integer has the high-order 16 bits of time, | |
1166 the second has the low 16 bits. (This is similar to the | |
1167 value of @code{current-time}; see @ref{Time of Day}.) | |
1168 | |
1169 @item | |
1170 The time of last modification as a list of two integers (as above). | |
1171 | |
1172 @item | |
1173 The time of last status change as a list of two integers (as above). | |
1174 | |
1175 @item | |
24951
7451b1458af1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22271
diff
changeset
|
1176 The size of the file in bytes. If the size is too large to fit in a |
7451b1458af1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22271
diff
changeset
|
1177 Lisp integer, this is a floating point number. |
6555 | 1178 |
1179 @item | |
7735
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
1180 The file's modes, as a string of ten letters or dashes, |
6555 | 1181 as in @samp{ls -l}. |
1182 | |
1183 @item | |
52978
1a5c50faf357
Replace @sc{foo} with @acronym{FOO}.
Eli Zaretskii <eliz@gnu.org>
parents:
52401
diff
changeset
|
1184 @code{t} if the file's @acronym{GID} would change if file were |
6555 | 1185 deleted and recreated; @code{nil} otherwise. |
1186 | |
1187 @item | |
17919
eb712b69e495
The inode number can be an integer.
Richard M. Stallman <rms@gnu.org>
parents:
17398
diff
changeset
|
1188 The file's inode number. If possible, this is an integer. If the inode |
eb712b69e495
The inode number can be an integer.
Richard M. Stallman <rms@gnu.org>
parents:
17398
diff
changeset
|
1189 number is too large to be represented as an integer in Emacs Lisp, then |
eb712b69e495
The inode number can be an integer.
Richard M. Stallman <rms@gnu.org>
parents:
17398
diff
changeset
|
1190 the value has the form @code{(@var{high} . @var{low})}, where @var{low} |
eb712b69e495
The inode number can be an integer.
Richard M. Stallman <rms@gnu.org>
parents:
17398
diff
changeset
|
1191 holds the low 16 bits. |
6555 | 1192 |
1193 @item | |
39296
5f4f6cf4a868
(File Attributes): Document that the device number can also be a cons cell.
Eli Zaretskii <eliz@gnu.org>
parents:
37582
diff
changeset
|
1194 The file system number of the file system that the file is in. |
5f4f6cf4a868
(File Attributes): Document that the device number can also be a cons cell.
Eli Zaretskii <eliz@gnu.org>
parents:
37582
diff
changeset
|
1195 Depending on the magnitude of the value, this can be either an integer |
5f4f6cf4a868
(File Attributes): Document that the device number can also be a cons cell.
Eli Zaretskii <eliz@gnu.org>
parents:
37582
diff
changeset
|
1196 or a cons cell, in the same manner as the inode number. This element |
5f4f6cf4a868
(File Attributes): Document that the device number can also be a cons cell.
Eli Zaretskii <eliz@gnu.org>
parents:
37582
diff
changeset
|
1197 and the file's inode number together give enough information to |
7735
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
1198 distinguish any two files on the system---no two files can have the same |
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
1199 values for both of these numbers. |
6555 | 1200 @end enumerate |
1201 | |
1202 For example, here are the file attributes for @file{files.texi}: | |
1203 | |
1204 @example | |
1205 @group | |
53109
420dc7ac8867
(File Attributes): Describe new parameter ID-FORMAT.
Lars Hansen <larsh@soem.dk>
parents:
52978
diff
changeset
|
1206 (file-attributes "files.texi" 'string) |
420dc7ac8867
(File Attributes): Describe new parameter ID-FORMAT.
Lars Hansen <larsh@soem.dk>
parents:
52978
diff
changeset
|
1207 @result{} (nil 1 "lh" "users" |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
47980
diff
changeset
|
1208 (8489 20284) |
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
47980
diff
changeset
|
1209 (8489 20284) |
6555 | 1210 (8489 20285) |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
47980
diff
changeset
|
1211 14906 "-rw-rw-rw-" |
21682
90da2489c498
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21007
diff
changeset
|
1212 nil 129500 -32252) |
6555 | 1213 @end group |
1214 @end example | |
1215 | |
1216 @noindent | |
1217 and here is how the result is interpreted: | |
1218 | |
1219 @table @code | |
1220 @item nil | |
1221 is neither a directory nor a symbolic link. | |
1222 | |
1223 @item 1 | |
1224 has only one name (the name @file{files.texi} in the current default | |
1225 directory). | |
1226 | |
53109
420dc7ac8867
(File Attributes): Describe new parameter ID-FORMAT.
Lars Hansen <larsh@soem.dk>
parents:
52978
diff
changeset
|
1227 @item "lh" |
420dc7ac8867
(File Attributes): Describe new parameter ID-FORMAT.
Lars Hansen <larsh@soem.dk>
parents:
52978
diff
changeset
|
1228 is owned by the user with name "lh". |
420dc7ac8867
(File Attributes): Describe new parameter ID-FORMAT.
Lars Hansen <larsh@soem.dk>
parents:
52978
diff
changeset
|
1229 |
420dc7ac8867
(File Attributes): Describe new parameter ID-FORMAT.
Lars Hansen <larsh@soem.dk>
parents:
52978
diff
changeset
|
1230 @item "users" |
420dc7ac8867
(File Attributes): Describe new parameter ID-FORMAT.
Lars Hansen <larsh@soem.dk>
parents:
52978
diff
changeset
|
1231 is in the group with name "users". |
6555 | 1232 |
1233 @item (8489 20284) | |
12522 | 1234 was last accessed on Aug 19 00:09. |
6555 | 1235 |
1236 @item (8489 20284) | |
1237 was last modified on Aug 19 00:09. | |
1238 | |
1239 @item (8489 20285) | |
1240 last had its inode changed on Aug 19 00:09. | |
1241 | |
1242 @item 14906 | |
25751
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
1243 is 14906 bytes long. (It may not contain 14906 characters, though, |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
1244 if some of the bytes belong to multibyte sequences.) |
6555 | 1245 |
1246 @item "-rw-rw-rw-" | |
1247 has a mode of read and write access for the owner, group, and world. | |
1248 | |
1249 @item nil | |
52978
1a5c50faf357
Replace @sc{foo} with @acronym{FOO}.
Eli Zaretskii <eliz@gnu.org>
parents:
52401
diff
changeset
|
1250 would retain the same @acronym{GID} if it were recreated. |
6555 | 1251 |
1252 @item 129500 | |
1253 has an inode number of 129500. | |
1254 @item -32252 | |
1255 is on file system number -32252. | |
1256 @end table | |
1257 @end defun | |
1258 | |
62585
78962e585d20
(Locating Files): New subsection. Describe locate-file and executable-find.
Eli Zaretskii <eliz@gnu.org>
parents:
61949
diff
changeset
|
1259 @node Locating Files |
78962e585d20
(Locating Files): New subsection. Describe locate-file and executable-find.
Eli Zaretskii <eliz@gnu.org>
parents:
61949
diff
changeset
|
1260 @subsection How to Locate Files in Standard Places |
78962e585d20
(Locating Files): New subsection. Describe locate-file and executable-find.
Eli Zaretskii <eliz@gnu.org>
parents:
61949
diff
changeset
|
1261 @cindex locate files |
78962e585d20
(Locating Files): New subsection. Describe locate-file and executable-find.
Eli Zaretskii <eliz@gnu.org>
parents:
61949
diff
changeset
|
1262 @cindex find files |
78962e585d20
(Locating Files): New subsection. Describe locate-file and executable-find.
Eli Zaretskii <eliz@gnu.org>
parents:
61949
diff
changeset
|
1263 |
62856
19deaa395e85
(Locating Files): Clean up the text.
Richard M. Stallman <rms@gnu.org>
parents:
62585
diff
changeset
|
1264 This section explains how to search for a file in a list of |
19deaa395e85
(Locating Files): Clean up the text.
Richard M. Stallman <rms@gnu.org>
parents:
62585
diff
changeset
|
1265 directories. One example is when you need to look for a program's |
19deaa395e85
(Locating Files): Clean up the text.
Richard M. Stallman <rms@gnu.org>
parents:
62585
diff
changeset
|
1266 executable file, e.g., to find out whether a given program is |
19deaa395e85
(Locating Files): Clean up the text.
Richard M. Stallman <rms@gnu.org>
parents:
62585
diff
changeset
|
1267 installed on the user's system. Another example is the search for |
62585
78962e585d20
(Locating Files): New subsection. Describe locate-file and executable-find.
Eli Zaretskii <eliz@gnu.org>
parents:
61949
diff
changeset
|
1268 Lisp libraries (@pxref{Library Search}). Such searches generally need |
62856
19deaa395e85
(Locating Files): Clean up the text.
Richard M. Stallman <rms@gnu.org>
parents:
62585
diff
changeset
|
1269 to try various possible file name extensions, in addition to various |
19deaa395e85
(Locating Files): Clean up the text.
Richard M. Stallman <rms@gnu.org>
parents:
62585
diff
changeset
|
1270 possible directories. Emacs provides a function for such a |
19deaa395e85
(Locating Files): Clean up the text.
Richard M. Stallman <rms@gnu.org>
parents:
62585
diff
changeset
|
1271 generalized search for a file. |
62585
78962e585d20
(Locating Files): New subsection. Describe locate-file and executable-find.
Eli Zaretskii <eliz@gnu.org>
parents:
61949
diff
changeset
|
1272 |
78962e585d20
(Locating Files): New subsection. Describe locate-file and executable-find.
Eli Zaretskii <eliz@gnu.org>
parents:
61949
diff
changeset
|
1273 @defun locate-file filename path &optional suffixes predicate |
62856
19deaa395e85
(Locating Files): Clean up the text.
Richard M. Stallman <rms@gnu.org>
parents:
62585
diff
changeset
|
1274 This function searches for a file whose name is @var{filename} in a |
19deaa395e85
(Locating Files): Clean up the text.
Richard M. Stallman <rms@gnu.org>
parents:
62585
diff
changeset
|
1275 list of directories given by @var{path}, trying the suffixes in |
19deaa395e85
(Locating Files): Clean up the text.
Richard M. Stallman <rms@gnu.org>
parents:
62585
diff
changeset
|
1276 @var{suffixes}. If it finds such a file, it returns the full |
19deaa395e85
(Locating Files): Clean up the text.
Richard M. Stallman <rms@gnu.org>
parents:
62585
diff
changeset
|
1277 @dfn{absolute file name} of the file (@pxref{Relative File Names}); |
19deaa395e85
(Locating Files): Clean up the text.
Richard M. Stallman <rms@gnu.org>
parents:
62585
diff
changeset
|
1278 otherwise it returns @code{nil}. |
62585
78962e585d20
(Locating Files): New subsection. Describe locate-file and executable-find.
Eli Zaretskii <eliz@gnu.org>
parents:
61949
diff
changeset
|
1279 |
78962e585d20
(Locating Files): New subsection. Describe locate-file and executable-find.
Eli Zaretskii <eliz@gnu.org>
parents:
61949
diff
changeset
|
1280 The optional argument @var{suffixes} gives the list of file-name |
62856
19deaa395e85
(Locating Files): Clean up the text.
Richard M. Stallman <rms@gnu.org>
parents:
62585
diff
changeset
|
1281 suffixes to append to @var{filename} when searching. |
19deaa395e85
(Locating Files): Clean up the text.
Richard M. Stallman <rms@gnu.org>
parents:
62585
diff
changeset
|
1282 @code{locate-file} tries each possible directory with each of these |
19deaa395e85
(Locating Files): Clean up the text.
Richard M. Stallman <rms@gnu.org>
parents:
62585
diff
changeset
|
1283 suffixes. If @var{suffixes} is @code{nil}, or @code{("")}, then there |
19deaa395e85
(Locating Files): Clean up the text.
Richard M. Stallman <rms@gnu.org>
parents:
62585
diff
changeset
|
1284 are no suffixes, and @var{filename} is used only as-is. Typical |
19deaa395e85
(Locating Files): Clean up the text.
Richard M. Stallman <rms@gnu.org>
parents:
62585
diff
changeset
|
1285 values of @var{suffixes} are @code{exec-suffixes} (@pxref{Subprocess |
19deaa395e85
(Locating Files): Clean up the text.
Richard M. Stallman <rms@gnu.org>
parents:
62585
diff
changeset
|
1286 Creation, exec-suffixes}) and @code{load-suffixes} (@pxref{Library |
19deaa395e85
(Locating Files): Clean up the text.
Richard M. Stallman <rms@gnu.org>
parents:
62585
diff
changeset
|
1287 Search, load-suffixes}). |
19deaa395e85
(Locating Files): Clean up the text.
Richard M. Stallman <rms@gnu.org>
parents:
62585
diff
changeset
|
1288 |
19deaa395e85
(Locating Files): Clean up the text.
Richard M. Stallman <rms@gnu.org>
parents:
62585
diff
changeset
|
1289 Typical values for @var{path} are @code{exec-path} (@pxref{Subprocess |
62585
78962e585d20
(Locating Files): New subsection. Describe locate-file and executable-find.
Eli Zaretskii <eliz@gnu.org>
parents:
61949
diff
changeset
|
1290 Creation, exec-path}) when looking for executable programs or |
78962e585d20
(Locating Files): New subsection. Describe locate-file and executable-find.
Eli Zaretskii <eliz@gnu.org>
parents:
61949
diff
changeset
|
1291 @code{load-path} (@pxref{Library Search, load-path}) when looking for |
62856
19deaa395e85
(Locating Files): Clean up the text.
Richard M. Stallman <rms@gnu.org>
parents:
62585
diff
changeset
|
1292 Lisp files. If @var{filename} is absolute, @var{path} has no effect, |
19deaa395e85
(Locating Files): Clean up the text.
Richard M. Stallman <rms@gnu.org>
parents:
62585
diff
changeset
|
1293 but the suffixes in @var{suffixes} are still tried. |
62585
78962e585d20
(Locating Files): New subsection. Describe locate-file and executable-find.
Eli Zaretskii <eliz@gnu.org>
parents:
61949
diff
changeset
|
1294 |
78962e585d20
(Locating Files): New subsection. Describe locate-file and executable-find.
Eli Zaretskii <eliz@gnu.org>
parents:
61949
diff
changeset
|
1295 The optional argument @var{predicate}, if non-@code{nil}, specifies |
78962e585d20
(Locating Files): New subsection. Describe locate-file and executable-find.
Eli Zaretskii <eliz@gnu.org>
parents:
61949
diff
changeset
|
1296 the predicate function to use for testing whether a candidate file is |
78962e585d20
(Locating Files): New subsection. Describe locate-file and executable-find.
Eli Zaretskii <eliz@gnu.org>
parents:
61949
diff
changeset
|
1297 suitable. The predicate function is passed the candidate file name as |
78962e585d20
(Locating Files): New subsection. Describe locate-file and executable-find.
Eli Zaretskii <eliz@gnu.org>
parents:
61949
diff
changeset
|
1298 its single argument. If @var{predicate} is @code{nil} or unspecified, |
78962e585d20
(Locating Files): New subsection. Describe locate-file and executable-find.
Eli Zaretskii <eliz@gnu.org>
parents:
61949
diff
changeset
|
1299 @code{locate-file} uses @code{file-readable-p} as the default |
78962e585d20
(Locating Files): New subsection. Describe locate-file and executable-find.
Eli Zaretskii <eliz@gnu.org>
parents:
61949
diff
changeset
|
1300 predicate. Useful non-default predicates include |
78962e585d20
(Locating Files): New subsection. Describe locate-file and executable-find.
Eli Zaretskii <eliz@gnu.org>
parents:
61949
diff
changeset
|
1301 @code{file-executable-p}, @code{file-directory-p}, and other |
78962e585d20
(Locating Files): New subsection. Describe locate-file and executable-find.
Eli Zaretskii <eliz@gnu.org>
parents:
61949
diff
changeset
|
1302 predicates described in @ref{Kinds of Files}. |
78962e585d20
(Locating Files): New subsection. Describe locate-file and executable-find.
Eli Zaretskii <eliz@gnu.org>
parents:
61949
diff
changeset
|
1303 |
78962e585d20
(Locating Files): New subsection. Describe locate-file and executable-find.
Eli Zaretskii <eliz@gnu.org>
parents:
61949
diff
changeset
|
1304 For compatibility, @var{predicate} can also be one of the symbols |
78962e585d20
(Locating Files): New subsection. Describe locate-file and executable-find.
Eli Zaretskii <eliz@gnu.org>
parents:
61949
diff
changeset
|
1305 @code{executable}, @code{readable}, @code{writable}, @code{exists}, or |
78962e585d20
(Locating Files): New subsection. Describe locate-file and executable-find.
Eli Zaretskii <eliz@gnu.org>
parents:
61949
diff
changeset
|
1306 a list of one or more of these symbols. |
78962e585d20
(Locating Files): New subsection. Describe locate-file and executable-find.
Eli Zaretskii <eliz@gnu.org>
parents:
61949
diff
changeset
|
1307 @end defun |
78962e585d20
(Locating Files): New subsection. Describe locate-file and executable-find.
Eli Zaretskii <eliz@gnu.org>
parents:
61949
diff
changeset
|
1308 |
78962e585d20
(Locating Files): New subsection. Describe locate-file and executable-find.
Eli Zaretskii <eliz@gnu.org>
parents:
61949
diff
changeset
|
1309 @cindex find executable program |
78962e585d20
(Locating Files): New subsection. Describe locate-file and executable-find.
Eli Zaretskii <eliz@gnu.org>
parents:
61949
diff
changeset
|
1310 @defun executable-find program |
78962e585d20
(Locating Files): New subsection. Describe locate-file and executable-find.
Eli Zaretskii <eliz@gnu.org>
parents:
61949
diff
changeset
|
1311 This function searches for the executable file of the named |
78962e585d20
(Locating Files): New subsection. Describe locate-file and executable-find.
Eli Zaretskii <eliz@gnu.org>
parents:
61949
diff
changeset
|
1312 @var{program} and returns the full absolute name of the executable, |
78962e585d20
(Locating Files): New subsection. Describe locate-file and executable-find.
Eli Zaretskii <eliz@gnu.org>
parents:
61949
diff
changeset
|
1313 including its file-name extensions, if any. It returns @code{nil} if |
78962e585d20
(Locating Files): New subsection. Describe locate-file and executable-find.
Eli Zaretskii <eliz@gnu.org>
parents:
61949
diff
changeset
|
1314 the file is not found. The functions searches in all the directories |
78962e585d20
(Locating Files): New subsection. Describe locate-file and executable-find.
Eli Zaretskii <eliz@gnu.org>
parents:
61949
diff
changeset
|
1315 in @code{exec-path} and tries all the file-name extensions in |
78962e585d20
(Locating Files): New subsection. Describe locate-file and executable-find.
Eli Zaretskii <eliz@gnu.org>
parents:
61949
diff
changeset
|
1316 @code{exec-suffixes}. |
78962e585d20
(Locating Files): New subsection. Describe locate-file and executable-find.
Eli Zaretskii <eliz@gnu.org>
parents:
61949
diff
changeset
|
1317 @end defun |
78962e585d20
(Locating Files): New subsection. Describe locate-file and executable-find.
Eli Zaretskii <eliz@gnu.org>
parents:
61949
diff
changeset
|
1318 |
21007
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
1319 @node Changing Files |
6555 | 1320 @section Changing File Names and Attributes |
1321 @cindex renaming files | |
1322 @cindex copying files | |
1323 @cindex deleting files | |
1324 @cindex linking files | |
1325 @cindex setting modes of files | |
1326 | |
1327 The functions in this section rename, copy, delete, link, and set the | |
1328 modes of files. | |
1329 | |
1330 In the functions that have an argument @var{newname}, if a file by the | |
1331 name of @var{newname} already exists, the actions taken depend on the | |
1332 value of the argument @var{ok-if-already-exists}: | |
1333 | |
1334 @itemize @bullet | |
1335 @item | |
1336 Signal a @code{file-already-exists} error if | |
1337 @var{ok-if-already-exists} is @code{nil}. | |
1338 | |
1339 @item | |
1340 Request confirmation if @var{ok-if-already-exists} is a number. | |
1341 | |
1342 @item | |
1343 Replace the old file without confirmation if @var{ok-if-already-exists} | |
1344 is any other value. | |
1345 @end itemize | |
1346 | |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1347 The next four commands all recursively follow symbolic links at all |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1348 levels of parent directories for their first argument, but, if that |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1349 argument is itself a symbolic link, then only @code{copy-file} |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1350 replaces it with its (recursive) target. |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1351 |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1352 @deffn Command add-name-to-file oldname newname &optional ok-if-already-exists |
6555 | 1353 @cindex file with multiple names |
1354 @cindex file hard link | |
1355 This function gives the file named @var{oldname} the additional name | |
1356 @var{newname}. This means that @var{newname} becomes a new ``hard | |
1357 link'' to @var{oldname}. | |
1358 | |
1359 In the first part of the following example, we list two files, | |
1360 @file{foo} and @file{foo3}. | |
1361 | |
1362 @example | |
1363 @group | |
22138
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
1364 % ls -li fo* |
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
1365 81908 -rw-rw-rw- 1 rms 29 Aug 18 20:32 foo |
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
1366 84302 -rw-rw-rw- 1 rms 24 Aug 18 20:31 foo3 |
6555 | 1367 @end group |
1368 @end example | |
1369 | |
16736
981e116b4ac6
Minor cleanups for overfull hboxes.
Richard M. Stallman <rms@gnu.org>
parents:
15913
diff
changeset
|
1370 Now we create a hard link, by calling @code{add-name-to-file}, then list |
981e116b4ac6
Minor cleanups for overfull hboxes.
Richard M. Stallman <rms@gnu.org>
parents:
15913
diff
changeset
|
1371 the files again. This shows two names for one file, @file{foo} and |
981e116b4ac6
Minor cleanups for overfull hboxes.
Richard M. Stallman <rms@gnu.org>
parents:
15913
diff
changeset
|
1372 @file{foo2}. |
6555 | 1373 |
1374 @example | |
1375 @group | |
22138
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
1376 (add-name-to-file "foo" "foo2") |
6555 | 1377 @result{} nil |
1378 @end group | |
1379 | |
1380 @group | |
22138
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
1381 % ls -li fo* |
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
1382 81908 -rw-rw-rw- 2 rms 29 Aug 18 20:32 foo |
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
1383 81908 -rw-rw-rw- 2 rms 29 Aug 18 20:32 foo2 |
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
1384 84302 -rw-rw-rw- 1 rms 24 Aug 18 20:31 foo3 |
6555 | 1385 @end group |
1386 @end example | |
1387 | |
22138
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
1388 Finally, we evaluate the following: |
6555 | 1389 |
1390 @example | |
22138
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
1391 (add-name-to-file "foo" "foo3" t) |
6555 | 1392 @end example |
1393 | |
1394 @noindent | |
1395 and list the files again. Now there are three names | |
1396 for one file: @file{foo}, @file{foo2}, and @file{foo3}. The old | |
1397 contents of @file{foo3} are lost. | |
1398 | |
1399 @example | |
1400 @group | |
22138
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
1401 (add-name-to-file "foo1" "foo3") |
6555 | 1402 @result{} nil |
1403 @end group | |
1404 | |
1405 @group | |
22138
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
1406 % ls -li fo* |
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
1407 81908 -rw-rw-rw- 3 rms 29 Aug 18 20:32 foo |
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
1408 81908 -rw-rw-rw- 3 rms 29 Aug 18 20:32 foo2 |
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
1409 81908 -rw-rw-rw- 3 rms 29 Aug 18 20:32 foo3 |
6555 | 1410 @end group |
1411 @end example | |
1412 | |
22138
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
1413 This function is meaningless on operating systems where multiple names |
25751
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
1414 for one file are not allowed. Some systems implement multiple names |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
1415 by copying the file instead. |
6555 | 1416 |
22138
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
1417 See also @code{file-nlinks} in @ref{File Attributes}. |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1418 @end deffn |
6555 | 1419 |
1420 @deffn Command rename-file filename newname &optional ok-if-already-exists | |
1421 This command renames the file @var{filename} as @var{newname}. | |
1422 | |
1423 If @var{filename} has additional names aside from @var{filename}, it | |
1424 continues to have those names. In fact, adding the name @var{newname} | |
1425 with @code{add-name-to-file} and then deleting @var{filename} has the | |
1426 same effect as renaming, aside from momentary intermediate states. | |
1427 @end deffn | |
1428 | |
61759
d9c520f08ec6
(Changing Files): Document MUSTBENEW arg in copy-file.
Richard M. Stallman <rms@gnu.org>
parents:
60444
diff
changeset
|
1429 @deffn Command copy-file oldname newname &optional ok-if-exists time mustbenew |
6555 | 1430 This command copies the file @var{oldname} to @var{newname}. An |
51913
3abc365e9d90
(Changing Files): copy-file allows dir as NEWNAME.
Richard M. Stallman <rms@gnu.org>
parents:
51793
diff
changeset
|
1431 error is signaled if @var{oldname} does not exist. If @var{newname} |
3abc365e9d90
(Changing Files): copy-file allows dir as NEWNAME.
Richard M. Stallman <rms@gnu.org>
parents:
51793
diff
changeset
|
1432 names a directory, it copies @var{oldname} into that directory, |
3abc365e9d90
(Changing Files): copy-file allows dir as NEWNAME.
Richard M. Stallman <rms@gnu.org>
parents:
51793
diff
changeset
|
1433 preserving its final name component. |
6555 | 1434 |
22138
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
1435 If @var{time} is non-@code{nil}, then this function gives the new file |
21007
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
1436 the same last-modified time that the old one has. (This works on only |
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
1437 some operating systems.) If setting the time gets an error, |
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
1438 @code{copy-file} signals a @code{file-date-error} error. |
6555 | 1439 |
51558
5a85c7c1d3ab
(Changing Files): copy-file copies file modes, too.
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51020
diff
changeset
|
1440 This function copies the file modes, too. |
5a85c7c1d3ab
(Changing Files): copy-file copies file modes, too.
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
51020
diff
changeset
|
1441 |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1442 In an interactive call, a prefix argument specifies a non-@code{nil} |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1443 value for @var{time}. |
61759
d9c520f08ec6
(Changing Files): Document MUSTBENEW arg in copy-file.
Richard M. Stallman <rms@gnu.org>
parents:
60444
diff
changeset
|
1444 |
d9c520f08ec6
(Changing Files): Document MUSTBENEW arg in copy-file.
Richard M. Stallman <rms@gnu.org>
parents:
60444
diff
changeset
|
1445 The argument @var{mustbenew} controls whether an existing file can be |
d9c520f08ec6
(Changing Files): Document MUSTBENEW arg in copy-file.
Richard M. Stallman <rms@gnu.org>
parents:
60444
diff
changeset
|
1446 overwritten. It works like the similarly-named argument of |
61793
2a5295f7077e
(Changing Files): Fix last change's cross-reference.
Eli Zaretskii <eliz@gnu.org>
parents:
61775
diff
changeset
|
1447 @code{write-region} (@pxref{Writing to Files, mustbenew}). |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1448 @end deffn |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1449 |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1450 @deffn Command make-symbolic-link filename newname &optional ok-if-exists |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1451 @pindex ln |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1452 @kindex file-already-exists |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1453 This command makes a symbolic link to @var{filename}, named |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1454 @var{newname}. This is like the shell command @samp{ln -s |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1455 @var{filename} @var{newname}}. |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1456 |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1457 This function is not available on systems that don't support symbolic |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1458 links. |
6555 | 1459 @end deffn |
1460 | |
1461 @deffn Command delete-file filename | |
1462 @pindex rm | |
1463 This command deletes the file @var{filename}, like the shell command | |
1464 @samp{rm @var{filename}}. If the file has multiple names, it continues | |
1465 to exist under the other names. | |
1466 | |
26696
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
1467 A suitable kind of @code{file-error} error is signaled if the file does |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
1468 not exist, or is not deletable. (On Unix and GNU/Linux, a file is |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
1469 deletable if its directory is writable.) |
6555 | 1470 |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1471 If @var{filename} is a symbolic link, @code{delete-file} does not |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1472 replace it with its target, but it does follow symbolic links at all |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1473 levels of parent directories. |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1474 |
6555 | 1475 See also @code{delete-directory} in @ref{Create/Delete Dirs}. |
1476 @end deffn | |
1477 | |
1478 @defun define-logical-name varname string | |
54025
8659505a7f3d
(Changing Files): Fix argname.
Richard M. Stallman <rms@gnu.org>
parents:
53575
diff
changeset
|
1479 This function defines the logical name @var{varname} to have the value |
6555 | 1480 @var{string}. It is available only on VMS. |
1481 @end defun | |
1482 | |
1483 @defun set-file-modes filename mode | |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1484 This function sets mode bits of @var{filename} to @var{mode} (which |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1485 must be an integer). Only the low 12 bits of @var{mode} are used. |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1486 This function recursively follows symbolic links at all levels for |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1487 @var{filename}. |
6555 | 1488 @end defun |
1489 | |
1490 @c Emacs 19 feature | |
1491 @defun set-default-file-modes mode | |
47514
e0d6f0b369d1
Add `umask' to the concept index.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
46956
diff
changeset
|
1492 @cindex umask |
6555 | 1493 This function sets the default file protection for new files created by |
1494 Emacs and its subprocesses. Every file created with Emacs initially has | |
28074
25557ce6a3a0
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
27259
diff
changeset
|
1495 this protection, or a subset of it (@code{write-region} will not give a |
25557ce6a3a0
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
27259
diff
changeset
|
1496 file execute permission even if the default file protection allows |
25557ce6a3a0
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
27259
diff
changeset
|
1497 execute permission). On Unix and GNU/Linux, the default protection is |
25557ce6a3a0
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
27259
diff
changeset
|
1498 the bitwise complement of the ``umask'' value. |
6555 | 1499 |
21007
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
1500 The argument @var{mode} must be an integer. On most systems, only the |
28074
25557ce6a3a0
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
27259
diff
changeset
|
1501 low 9 bits of @var{mode} are meaningful. You can use the Lisp construct |
25557ce6a3a0
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
27259
diff
changeset
|
1502 for octal character codes to enter @var{mode}; for example, |
25557ce6a3a0
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
27259
diff
changeset
|
1503 |
25557ce6a3a0
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
27259
diff
changeset
|
1504 @example |
25557ce6a3a0
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
27259
diff
changeset
|
1505 (set-default-file-modes ?\644) |
25557ce6a3a0
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
27259
diff
changeset
|
1506 @end example |
6555 | 1507 |
1508 Saving a modified version of an existing file does not count as creating | |
28074
25557ce6a3a0
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
27259
diff
changeset
|
1509 the file; it preserves the existing file's mode, whatever that is. So |
25557ce6a3a0
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
27259
diff
changeset
|
1510 the default file protection has no effect. |
6555 | 1511 @end defun |
1512 | |
1513 @defun default-file-modes | |
1514 This function returns the current default protection value. | |
1515 @end defun | |
1516 | |
55192
dd5538a91d27
(Changing Files): Document set-file-times.
Eli Zaretskii <eliz@gnu.org>
parents:
54861
diff
changeset
|
1517 @defun set-file-times filename &optional time |
dd5538a91d27
(Changing Files): Document set-file-times.
Eli Zaretskii <eliz@gnu.org>
parents:
54861
diff
changeset
|
1518 This function sets the access and modification times of @var{filename} |
dd5538a91d27
(Changing Files): Document set-file-times.
Eli Zaretskii <eliz@gnu.org>
parents:
54861
diff
changeset
|
1519 to @var{time}. The return value is @code{t} if the times are successfully |
dd5538a91d27
(Changing Files): Document set-file-times.
Eli Zaretskii <eliz@gnu.org>
parents:
54861
diff
changeset
|
1520 set, otherwise it is @code{nil}. @var{time} defaults to the current |
dd5538a91d27
(Changing Files): Document set-file-times.
Eli Zaretskii <eliz@gnu.org>
parents:
54861
diff
changeset
|
1521 time and must be in the format returned by @code{current-time} |
dd5538a91d27
(Changing Files): Document set-file-times.
Eli Zaretskii <eliz@gnu.org>
parents:
54861
diff
changeset
|
1522 (@pxref{Time of Day}). |
dd5538a91d27
(Changing Files): Document set-file-times.
Eli Zaretskii <eliz@gnu.org>
parents:
54861
diff
changeset
|
1523 @end defun |
dd5538a91d27
(Changing Files): Document set-file-times.
Eli Zaretskii <eliz@gnu.org>
parents:
54861
diff
changeset
|
1524 |
7088
5a93e6fb43a4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
6555
diff
changeset
|
1525 @cindex MS-DOS and file modes |
5a93e6fb43a4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
6555
diff
changeset
|
1526 @cindex file modes and MS-DOS |
5a93e6fb43a4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
6555
diff
changeset
|
1527 On MS-DOS, there is no such thing as an ``executable'' file mode bit. |
25751
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
1528 So Emacs considers a file executable if its name ends in one of the |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
1529 standard executable extensions, such as @file{.com}, @file{.bat}, |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
1530 @file{.exe}, and some others. Files that begin with the Unix-standard |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
1531 @samp{#!} signature, such as shell and Perl scripts, are also considered |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
1532 as executable files. This is reflected in the values returned by |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
1533 @code{file-modes} and @code{file-attributes}. Directories are also |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
1534 reported with executable bit set, for compatibility with Unix. |
7088
5a93e6fb43a4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
6555
diff
changeset
|
1535 |
6555 | 1536 @node File Names |
1537 @section File Names | |
1538 @cindex file names | |
1539 | |
1540 Files are generally referred to by their names, in Emacs as elsewhere. | |
1541 File names in Emacs are represented as strings. The functions that | |
1542 operate on a file all expect a file name argument. | |
1543 | |
1544 In addition to operating on files themselves, Emacs Lisp programs | |
21007
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
1545 often need to operate on file names; i.e., to take them apart and to use |
6555 | 1546 part of a name to construct related file names. This section describes |
1547 how to manipulate file names. | |
1548 | |
1549 The functions in this section do not actually access files, so they | |
1550 can operate on file names that do not refer to an existing file or | |
1551 directory. | |
1552 | |
28635
cda2b6ed6aec
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
28608
diff
changeset
|
1553 On MS-DOS and MS-Windows, these functions (like the function that |
cda2b6ed6aec
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
28608
diff
changeset
|
1554 actually operate on files) accept MS-DOS or MS-Windows file-name syntax, |
cda2b6ed6aec
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
28608
diff
changeset
|
1555 where backslashes separate the components, as well as Unix syntax; but |
cda2b6ed6aec
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
28608
diff
changeset
|
1556 they always return Unix syntax. On VMS, these functions (and the ones |
cda2b6ed6aec
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
28608
diff
changeset
|
1557 that operate on files) understand both VMS file-name syntax and Unix |
cda2b6ed6aec
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
28608
diff
changeset
|
1558 syntax. This enables Lisp programs to specify file names in Unix syntax |
cda2b6ed6aec
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
28608
diff
changeset
|
1559 and work properly on all systems without change. |
6555 | 1560 |
1561 @menu | |
1562 * File Name Components:: The directory part of a file name, and the rest. | |
46956
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1563 * Relative File Names:: Some file names are relative to a current directory. |
6555 | 1564 * Directory Names:: A directory's name as a directory |
1565 is different from its name as a file. | |
1566 * File Name Expansion:: Converting relative file names to absolute ones. | |
1567 * Unique File Names:: Generating names for temporary files. | |
1568 * File Name Completion:: Finding the completions for a given file name. | |
15765
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
1569 * Standard File Names:: If your package uses a fixed file name, |
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
1570 how to handle various operating systems simply. |
6555 | 1571 @end menu |
1572 | |
1573 @node File Name Components | |
1574 @subsection File Name Components | |
1575 @cindex directory part (of file name) | |
1576 @cindex nondirectory part (of file name) | |
1577 @cindex version number (in file name) | |
1578 | |
1579 The operating system groups files into directories. To specify a | |
7735
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
1580 file, you must specify the directory and the file's name within that |
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
1581 directory. Therefore, Emacs considers a file name as having two main |
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
1582 parts: the @dfn{directory name} part, and the @dfn{nondirectory} part |
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
1583 (or @dfn{file name within the directory}). Either part may be empty. |
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
1584 Concatenating these two parts reproduces the original file name. |
6555 | 1585 |
25751
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
1586 On most systems, the directory part is everything up to and including |
28635
cda2b6ed6aec
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
28608
diff
changeset
|
1587 the last slash (backslash is also allowed in input on MS-DOS or |
cda2b6ed6aec
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
28608
diff
changeset
|
1588 MS-Windows); the nondirectory part is the rest. The rules in VMS syntax |
cda2b6ed6aec
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
28608
diff
changeset
|
1589 are complicated. |
6555 | 1590 |
1591 For some purposes, the nondirectory part is further subdivided into | |
25751
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
1592 the name proper and the @dfn{version number}. On most systems, only |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
1593 backup files have version numbers in their names. On VMS, every file |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
1594 has a version number, but most of the time the file name actually used |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
1595 in Emacs omits the version number, so that version numbers in Emacs are |
21007
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
1596 found mostly in directory lists. |
6555 | 1597 |
1598 @defun file-name-directory filename | |
46956
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1599 This function returns the directory part of @var{filename}, as a |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1600 directory name (@pxref{Directory Names}), or @code{nil} if |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1601 @var{filename} does not include a directory part. |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1602 |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1603 On GNU and Unix systems, a string returned by this function always |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1604 ends in a slash. On MSDOS it can also end in a colon. On VMS, it |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1605 returns a string ending in one of the three characters @samp{:}, |
6555 | 1606 @samp{]}, or @samp{>}. |
1607 | |
1608 @example | |
1609 @group | |
1610 (file-name-directory "lewis/foo") ; @r{Unix example} | |
1611 @result{} "lewis/" | |
1612 @end group | |
1613 @group | |
1614 (file-name-directory "foo") ; @r{Unix example} | |
1615 @result{} nil | |
1616 @end group | |
1617 @group | |
1618 (file-name-directory "[X]FOO.TMP") ; @r{VMS example} | |
1619 @result{} "[X]" | |
1620 @end group | |
1621 @end example | |
1622 @end defun | |
1623 | |
1624 @defun file-name-nondirectory filename | |
21007
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
1625 This function returns the nondirectory part of @var{filename}. |
6555 | 1626 |
1627 @example | |
1628 @group | |
1629 (file-name-nondirectory "lewis/foo") | |
1630 @result{} "foo" | |
1631 @end group | |
1632 @group | |
1633 (file-name-nondirectory "foo") | |
1634 @result{} "foo" | |
1635 @end group | |
1636 @group | |
46956
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1637 (file-name-nondirectory "lewis/") |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1638 @result{} "" |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1639 @end group |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1640 @group |
6555 | 1641 ;; @r{The following example is accurate only on VMS.} |
1642 (file-name-nondirectory "[X]FOO.TMP") | |
1643 @result{} "FOO.TMP" | |
1644 @end group | |
1645 @end example | |
1646 @end defun | |
1647 | |
26696
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
1648 @defun file-name-sans-versions filename &optional keep-backup-version |
21007
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
1649 This function returns @var{filename} with any file version numbers, |
26696
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
1650 backup version numbers, or trailing tildes discarded. |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
1651 |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
1652 If @var{keep-backup-version} is non-@code{nil}, then true file version |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
1653 numbers understood as such by the file system are discarded from the |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
1654 return value, but backup version numbers are kept. |
6555 | 1655 |
1656 @example | |
1657 @group | |
1658 (file-name-sans-versions "~rms/foo.~1~") | |
1659 @result{} "~rms/foo" | |
1660 @end group | |
1661 @group | |
1662 (file-name-sans-versions "~rms/foo~") | |
1663 @result{} "~rms/foo" | |
1664 @end group | |
1665 @group | |
1666 (file-name-sans-versions "~rms/foo") | |
1667 @result{} "~rms/foo" | |
1668 @end group | |
1669 @group | |
1670 ;; @r{The following example applies to VMS only.} | |
1671 (file-name-sans-versions "foo;23") | |
1672 @result{} "foo" | |
1673 @end group | |
1674 @end example | |
1675 @end defun | |
1676 | |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1677 @defun file-name-extension filename &optional period |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1678 This function returns @var{filename}'s final ``extension'', if any, |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1679 after applying @code{file-name-sans-versions} to remove any |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1680 version/backup part. The extension, in a file name, is the part that |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1681 starts with the last @samp{.} in the last name component (minus |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1682 any version/backup part). |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1683 |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1684 This function returns @code{nil} for extensionless file names such as |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1685 @file{foo}. It returns @code{""} for null extensions, as in |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1686 @file{foo.}. If the last component of a file name begins with a |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1687 @samp{.}, that @samp{.} doesn't count as the beginning of an |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1688 extension. Thus, @file{.emacs}'s ``extension'' is @code{nil}, not |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1689 @samp{.emacs}. |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1690 |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1691 If @var{period} is non-@code{nil}, then the returned value includes |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1692 the period that delimits the extension, and if @var{filename} has no |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1693 extension, the value is @code{""}. |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1694 @end defun |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1695 |
12067 | 1696 @defun file-name-sans-extension filename |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1697 This function returns @var{filename} minus its extension, if any. The |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1698 version/backup part, if present, is only removed if the file has an |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1699 extension. For example, |
12098 | 1700 |
1701 @example | |
1702 (file-name-sans-extension "foo.lose.c") | |
1703 @result{} "foo.lose" | |
1704 (file-name-sans-extension "big.hack/foo") | |
1705 @result{} "big.hack/foo" | |
40188
cd1cd95ca64e
(File Name Components): Update the description of
Eli Zaretskii <eliz@gnu.org>
parents:
39883
diff
changeset
|
1706 (file-name-sans-extension "/my/home/.emacs") |
47980
5492d1831d2a
From Michael Albinus.
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
47514
diff
changeset
|
1707 @result{} "/my/home/.emacs" |
40188
cd1cd95ca64e
(File Name Components): Update the description of
Eli Zaretskii <eliz@gnu.org>
parents:
39883
diff
changeset
|
1708 (file-name-sans-extension "/my/home/.emacs.el") |
cd1cd95ca64e
(File Name Components): Update the description of
Eli Zaretskii <eliz@gnu.org>
parents:
39883
diff
changeset
|
1709 @result{} "/my/home/.emacs" |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1710 (file-name-sans-extension "~/foo.el.~3~") |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1711 @result{} "~/foo" |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1712 (file-name-sans-extension "~/foo.~3~") |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1713 @result{} "~/foo.~3~" |
12098 | 1714 @end example |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1715 |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1716 Note that the @samp{.~3~} in the two last examples is the backup part, |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1717 not an extension. |
12067 | 1718 @end defun |
1719 | |
28635
cda2b6ed6aec
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
28608
diff
changeset
|
1720 @ignore |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
47980
diff
changeset
|
1721 Andrew Innes says that this |
28635
cda2b6ed6aec
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
28608
diff
changeset
|
1722 |
cda2b6ed6aec
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
28608
diff
changeset
|
1723 @c @defvar directory-sep-char |
cda2b6ed6aec
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
28608
diff
changeset
|
1724 @c @tindex directory-sep-char |
cda2b6ed6aec
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
28608
diff
changeset
|
1725 This variable holds the character that Emacs normally uses to separate |
cda2b6ed6aec
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
28608
diff
changeset
|
1726 file name components. The default value is @code{?/}, but on MS-Windows |
cda2b6ed6aec
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
28608
diff
changeset
|
1727 you can set it to @code{?\\}; then the functions that transform file names |
cda2b6ed6aec
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
28608
diff
changeset
|
1728 use backslashes in their output. |
cda2b6ed6aec
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
28608
diff
changeset
|
1729 |
cda2b6ed6aec
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
28608
diff
changeset
|
1730 File names using backslashes work as input to Lisp primitives even on |
cda2b6ed6aec
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
28608
diff
changeset
|
1731 MS-DOS and MS-Windows, even if @code{directory-sep-char} has its default |
cda2b6ed6aec
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
28608
diff
changeset
|
1732 value of @code{?/}. |
28608
c46c2efa3731
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
28074
diff
changeset
|
1733 @end defvar |
28635
cda2b6ed6aec
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
28608
diff
changeset
|
1734 @end ignore |
28608
c46c2efa3731
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
28074
diff
changeset
|
1735 |
6555 | 1736 @node Relative File Names |
1737 @subsection Absolute and Relative File Names | |
1738 @cindex absolute file name | |
1739 @cindex relative file name | |
1740 | |
1741 All the directories in the file system form a tree starting at the | |
1742 root directory. A file name can specify all the directory names | |
1743 starting from the root of the tree; then it is called an @dfn{absolute} | |
1744 file name. Or it can specify the position of the file in the tree | |
26696
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
1745 relative to a default directory; then it is called a @dfn{relative} file |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
1746 name. On Unix and GNU/Linux, an absolute file name starts with a slash |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
1747 or a tilde (@samp{~}), and a relative one does not. On MS-DOS and |
25751
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
1748 MS-Windows, an absolute file name starts with a slash or a backslash, or |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
1749 with a drive specification @samp{@var{x}:/}, where @var{x} is the |
26696
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
1750 @dfn{drive letter}. The rules on VMS are complicated. |
6555 | 1751 |
1752 @defun file-name-absolute-p filename | |
1753 This function returns @code{t} if file @var{filename} is an absolute | |
1754 file name, @code{nil} otherwise. On VMS, this function understands both | |
1755 Unix syntax and VMS syntax. | |
1756 | |
1757 @example | |
1758 @group | |
1759 (file-name-absolute-p "~rms/foo") | |
1760 @result{} t | |
1761 @end group | |
1762 @group | |
1763 (file-name-absolute-p "rms/foo") | |
1764 @result{} nil | |
1765 @end group | |
1766 @group | |
1767 (file-name-absolute-p "/user/rms/foo") | |
1768 @result{} t | |
1769 @end group | |
1770 @end example | |
1771 @end defun | |
1772 | |
46956
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1773 @node Directory Names |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1774 @comment node-name, next, previous, up |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1775 @subsection Directory Names |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1776 @cindex directory name |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1777 @cindex file name of directory |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1778 |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1779 A @dfn{directory name} is the name of a directory. A directory is |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1780 actually a kind of file, so it has a file name, which is related to |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1781 the directory name but not identical to it. (This is not quite the |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1782 same as the usual Unix terminology.) These two different names for |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1783 the same entity are related by a syntactic transformation. On GNU and |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1784 Unix systems, this is simple: a directory name ends in a slash, |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1785 whereas the directory's name as a file lacks that slash. On MSDOS and |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1786 VMS, the relationship is more complicated. |
46956
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1787 |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1788 The difference between a directory name and its name as a file is |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1789 subtle but crucial. When an Emacs variable or function argument is |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1790 described as being a directory name, a file name of a directory is not |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1791 acceptable. When @code{file-name-directory} returns a string, that is |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1792 always a directory name. |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1793 |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1794 The following two functions convert between directory names and file |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1795 names. They do nothing special with environment variable substitutions |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1796 such as @samp{$HOME}, and the constructs @samp{~}, @samp{.} and @samp{..}. |
46956
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1797 |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1798 @defun file-name-as-directory filename |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1799 This function returns a string representing @var{filename} in a form |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1800 that the operating system will interpret as the name of a directory. On |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1801 most systems, this means appending a slash to the string (if it does not |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1802 already end in one). On VMS, the function converts a string of the form |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1803 @file{[X]Y.DIR.1} to the form @file{[X.Y]}. |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1804 |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1805 @example |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1806 @group |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1807 (file-name-as-directory "~rms/lewis") |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1808 @result{} "~rms/lewis/" |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1809 @end group |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1810 @end example |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1811 @end defun |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1812 |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1813 @defun directory-file-name dirname |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1814 This function returns a string representing @var{dirname} in a form that |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1815 the operating system will interpret as the name of a file. On most |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1816 systems, this means removing the final slash (or backslash) from the |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1817 string. On VMS, the function converts a string of the form @file{[X.Y]} |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1818 to @file{[X]Y.DIR.1}. |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1819 |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1820 @example |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1821 @group |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1822 (directory-file-name "~lewis/") |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1823 @result{} "~lewis" |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1824 @end group |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1825 @end example |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1826 @end defun |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1827 |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1828 Given a directory name, you can combine it with a relative file name |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1829 using @code{concat}: |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1830 |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1831 @example |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1832 (concat @var{dirname} @var{relfile}) |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1833 @end example |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1834 |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1835 @noindent |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1836 Be sure to verify that the file name is relative before doing that. |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1837 If you use an absolute file name, the results could be syntactically |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1838 invalid or refer to the wrong file. |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1839 |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1840 If you want to use a directory file name in making such a |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1841 combination, you must first convert it to a directory name using |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1842 @code{file-name-as-directory}: |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1843 |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1844 @example |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1845 (concat (file-name-as-directory @var{dirfile}) @var{relfile}) |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1846 @end example |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1847 |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1848 @noindent |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1849 Don't try concatenating a slash by hand, as in |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1850 |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1851 @example |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1852 ;;; @r{Wrong!} |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1853 (concat @var{dirfile} "/" @var{relfile}) |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1854 @end example |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1855 |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1856 @noindent |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1857 because this is not portable. Always use |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1858 @code{file-name-as-directory}. |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1859 |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1860 @cindex directory name abbreviation |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1861 Directory name abbreviations are useful for directories that are |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1862 normally accessed through symbolic links. Sometimes the users recognize |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1863 primarily the link's name as ``the name'' of the directory, and find it |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1864 annoying to see the directory's ``real'' name. If you define the link |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1865 name as an abbreviation for the ``real'' name, Emacs shows users the |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1866 abbreviation instead. |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1867 |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1868 @defvar directory-abbrev-alist |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1869 The variable @code{directory-abbrev-alist} contains an alist of |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1870 abbreviations to use for file directories. Each element has the form |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1871 @code{(@var{from} . @var{to})}, and says to replace @var{from} with |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1872 @var{to} when it appears in a directory name. The @var{from} string is |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1873 actually a regular expression; it should always start with @samp{^}. |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1874 The @var{to} string should be an ordinary absolute directory name. Do |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1875 not use @samp{~} to stand for a home directory in that string. The |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1876 function @code{abbreviate-file-name} performs these substitutions. |
46956
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1877 |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1878 You can set this variable in @file{site-init.el} to describe the |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1879 abbreviations appropriate for your site. |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1880 |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1881 Here's an example, from a system on which file system @file{/home/fsf} |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1882 and so on are normally accessed through symbolic links named @file{/fsf} |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1883 and so on. |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1884 |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1885 @example |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1886 (("^/home/fsf" . "/fsf") |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1887 ("^/home/gp" . "/gp") |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1888 ("^/home/gd" . "/gd")) |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1889 @end example |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1890 @end defvar |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1891 |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1892 To convert a directory name to its abbreviation, use this |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1893 function: |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1894 |
56215 | 1895 @defun abbreviate-file-name filename |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1896 @anchor{Definition of abbreviate-file-name} |
46956
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1897 This function applies abbreviations from @code{directory-abbrev-alist} |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1898 to its argument, and substitutes @samp{~} for the user's home |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1899 directory. You can use it for directory names and for file names, |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1900 because it recognizes abbreviations even as part of the name. |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1901 @end defun |
2c01ee3e5305
Move the node Relative Files before Directory Names. Show what
Richard M. Stallman <rms@gnu.org>
parents:
45979
diff
changeset
|
1902 |
6555 | 1903 @node File Name Expansion |
1904 @subsection Functions that Expand Filenames | |
1905 @cindex expansion of file names | |
1906 | |
1907 @dfn{Expansion} of a file name means converting a relative file name | |
1908 to an absolute one. Since this is done relative to a default directory, | |
1909 you must specify the default directory name as well as the file name to | |
1910 be expanded. Expansion also simplifies file names by eliminating | |
1911 redundancies such as @file{./} and @file{@var{name}/../}. | |
1912 | |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1913 In the next two functions, the @var{directory} argument can be either |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1914 a directory name or a directory file name. @xref{Directory Names}. |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1915 |
6555 | 1916 @defun expand-file-name filename &optional directory |
1917 This function converts @var{filename} to an absolute file name. If | |
21007
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
1918 @var{directory} is supplied, it is the default directory to start with |
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
1919 if @var{filename} is relative. (The value of @var{directory} should |
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
1920 itself be an absolute directory name; it may start with @samp{~}.) |
6555 | 1921 Otherwise, the current buffer's value of @code{default-directory} is |
1922 used. For example: | |
1923 | |
1924 @example | |
1925 @group | |
1926 (expand-file-name "foo") | |
1927 @result{} "/xcssun/users/rms/lewis/foo" | |
1928 @end group | |
1929 @group | |
1930 (expand-file-name "../foo") | |
1931 @result{} "/xcssun/users/rms/foo" | |
1932 @end group | |
1933 @group | |
1934 (expand-file-name "foo" "/usr/spool/") | |
1935 @result{} "/usr/spool/foo" | |
1936 @end group | |
1937 @group | |
1938 (expand-file-name "$HOME/foo") | |
1939 @result{} "/xcssun/users/rms/lewis/$HOME/foo" | |
1940 @end group | |
1941 @end example | |
1942 | |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1943 If the part of the combined file name before the first slash is |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1944 @samp{~}, it expands to the value of the @env{HOME} environment |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1945 variable (usually your home directory). If the part before the first |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1946 slash is @samp{~@var{user}} and if @var{user} is a valid login name, |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1947 it expands to @var{user}'s home directory. |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1948 |
6555 | 1949 Filenames containing @samp{.} or @samp{..} are simplified to their |
1950 canonical form: | |
1951 | |
1952 @example | |
1953 @group | |
1954 (expand-file-name "bar/../foo") | |
1955 @result{} "/xcssun/users/rms/lewis/foo" | |
1956 @end group | |
1957 @end example | |
1958 | |
1959 Note that @code{expand-file-name} does @emph{not} expand environment | |
1960 variables; only @code{substitute-in-file-name} does that. | |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1961 |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1962 Note also that @code{expand-file-name} does not follow symbolic links |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1963 at any level. This results in a difference between the way |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1964 @code{file-truename} and @code{expand-file-name} treat @samp{..}. |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1965 Assuming that @samp{/tmp/bar} is a symbolic link to the directory |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1966 @samp{/tmp/foo/bar} we get: |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1967 |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1968 @example |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1969 @group |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1970 (file-truename "/tmp/bar/../myfile") |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1971 @result{} "/tmp/foo/myfile" |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1972 @end group |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1973 @group |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1974 (expand-file-name "/tmp/bar/../myfile") |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1975 @result{} "/tmp/myfile" |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1976 @end group |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1977 @end example |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1978 |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1979 If you may need to follow symbolic links preceding @samp{..}, you |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1980 should make sure to call @code{file-truename} without prior direct or |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
1981 indirect calls to @code{expand-file-name}. @xref{Truenames}. |
6555 | 1982 @end defun |
1983 | |
1984 @c Emacs 19 feature | |
26696
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
1985 @defun file-relative-name filename &optional directory |
6555 | 1986 This function does the inverse of expansion---it tries to return a |
7735
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
1987 relative name that is equivalent to @var{filename} when interpreted |
26696
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
1988 relative to @var{directory}. If @var{directory} is omitted or |
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
1989 @code{nil}, it defaults to the current buffer's default directory. |
17398
a5d9cbc4e2c5
(file-relative-name): Say correctly when the value is absolute.
Richard M. Stallman <rms@gnu.org>
parents:
16736
diff
changeset
|
1990 |
a5d9cbc4e2c5
(file-relative-name): Say correctly when the value is absolute.
Richard M. Stallman <rms@gnu.org>
parents:
16736
diff
changeset
|
1991 On some operating systems, an absolute file name begins with a device |
a5d9cbc4e2c5
(file-relative-name): Say correctly when the value is absolute.
Richard M. Stallman <rms@gnu.org>
parents:
16736
diff
changeset
|
1992 name. On such systems, @var{filename} has no relative equivalent based |
a5d9cbc4e2c5
(file-relative-name): Say correctly when the value is absolute.
Richard M. Stallman <rms@gnu.org>
parents:
16736
diff
changeset
|
1993 on @var{directory} if they start with two different device names. In |
a5d9cbc4e2c5
(file-relative-name): Say correctly when the value is absolute.
Richard M. Stallman <rms@gnu.org>
parents:
16736
diff
changeset
|
1994 this case, @code{file-relative-name} returns @var{filename} in absolute |
a5d9cbc4e2c5
(file-relative-name): Say correctly when the value is absolute.
Richard M. Stallman <rms@gnu.org>
parents:
16736
diff
changeset
|
1995 form. |
6555 | 1996 |
1997 @example | |
1998 (file-relative-name "/foo/bar" "/foo/") | |
22138
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
1999 @result{} "bar" |
6555 | 2000 (file-relative-name "/foo/bar" "/hack/") |
28681
bf112ad58dc7
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
28635
diff
changeset
|
2001 @result{} "../foo/bar" |
6555 | 2002 @end example |
2003 @end defun | |
2004 | |
2005 @defvar default-directory | |
2006 The value of this buffer-local variable is the default directory for the | |
2007 current buffer. It should be an absolute directory name; it may start | |
21682
90da2489c498
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21007
diff
changeset
|
2008 with @samp{~}. This variable is buffer-local in every buffer. |
6555 | 2009 |
2010 @code{expand-file-name} uses the default directory when its second | |
2011 argument is @code{nil}. | |
2012 | |
25751
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2013 Aside from VMS, the value is always a string ending with a slash. |
6555 | 2014 |
2015 @example | |
2016 @group | |
2017 default-directory | |
2018 @result{} "/user/lewis/manual/" | |
2019 @end group | |
2020 @end example | |
2021 @end defvar | |
2022 | |
56215 | 2023 @defun substitute-in-file-name filename |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2024 @anchor{Definition of substitute-in-file-name} |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2025 This function replaces environment variable references in |
51793
ccbf5ac3316d
(File Name Expansion): Warn about iterative use of substitute-in-file-name.
Richard M. Stallman <rms@gnu.org>
parents:
51654
diff
changeset
|
2026 @var{filename} with the environment variable values. Following |
ccbf5ac3316d
(File Name Expansion): Warn about iterative use of substitute-in-file-name.
Richard M. Stallman <rms@gnu.org>
parents:
51654
diff
changeset
|
2027 standard Unix shell syntax, @samp{$} is the prefix to substitute an |
ccbf5ac3316d
(File Name Expansion): Warn about iterative use of substitute-in-file-name.
Richard M. Stallman <rms@gnu.org>
parents:
51654
diff
changeset
|
2028 environment variable value. If the input contains @samp{$$}, that is |
ccbf5ac3316d
(File Name Expansion): Warn about iterative use of substitute-in-file-name.
Richard M. Stallman <rms@gnu.org>
parents:
51654
diff
changeset
|
2029 converted to @samp{$}; this gives the user a way to ``quote'' a |
ccbf5ac3316d
(File Name Expansion): Warn about iterative use of substitute-in-file-name.
Richard M. Stallman <rms@gnu.org>
parents:
51654
diff
changeset
|
2030 @samp{$}. |
6555 | 2031 |
2032 The environment variable name is the series of alphanumeric characters | |
2033 (including underscores) that follow the @samp{$}. If the character following | |
2034 the @samp{$} is a @samp{@{}, then the variable name is everything up to the | |
2035 matching @samp{@}}. | |
2036 | |
51793
ccbf5ac3316d
(File Name Expansion): Warn about iterative use of substitute-in-file-name.
Richard M. Stallman <rms@gnu.org>
parents:
51654
diff
changeset
|
2037 Calling @code{substitute-in-file-name} on output produced by |
ccbf5ac3316d
(File Name Expansion): Warn about iterative use of substitute-in-file-name.
Richard M. Stallman <rms@gnu.org>
parents:
51654
diff
changeset
|
2038 @code{substitute-in-file-name} tends to give incorrect results. For |
ccbf5ac3316d
(File Name Expansion): Warn about iterative use of substitute-in-file-name.
Richard M. Stallman <rms@gnu.org>
parents:
51654
diff
changeset
|
2039 instance, use of @samp{$$} to quote a single @samp{$} won't work |
ccbf5ac3316d
(File Name Expansion): Warn about iterative use of substitute-in-file-name.
Richard M. Stallman <rms@gnu.org>
parents:
51654
diff
changeset
|
2040 properly, and @samp{$} in an environment variable's value could lead |
ccbf5ac3316d
(File Name Expansion): Warn about iterative use of substitute-in-file-name.
Richard M. Stallman <rms@gnu.org>
parents:
51654
diff
changeset
|
2041 to repeated substitution. Therefore, programs that call this function |
ccbf5ac3316d
(File Name Expansion): Warn about iterative use of substitute-in-file-name.
Richard M. Stallman <rms@gnu.org>
parents:
51654
diff
changeset
|
2042 and put the output where it will be passed to this function need to |
ccbf5ac3316d
(File Name Expansion): Warn about iterative use of substitute-in-file-name.
Richard M. Stallman <rms@gnu.org>
parents:
51654
diff
changeset
|
2043 double all @samp{$} characters to prevent subsequent incorrect |
ccbf5ac3316d
(File Name Expansion): Warn about iterative use of substitute-in-file-name.
Richard M. Stallman <rms@gnu.org>
parents:
51654
diff
changeset
|
2044 results. |
ccbf5ac3316d
(File Name Expansion): Warn about iterative use of substitute-in-file-name.
Richard M. Stallman <rms@gnu.org>
parents:
51654
diff
changeset
|
2045 |
6555 | 2046 @c Wordy to avoid overfull hbox. --rjc 15mar92 |
2047 Here we assume that the environment variable @code{HOME}, which holds | |
2048 the user's home directory name, has value @samp{/xcssun/users/rms}. | |
2049 | |
2050 @example | |
2051 @group | |
2052 (substitute-in-file-name "$HOME/foo") | |
2053 @result{} "/xcssun/users/rms/foo" | |
2054 @end group | |
2055 @end example | |
2056 | |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2057 After substitution, if a @samp{~} or a @samp{/} appears immediately |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2058 after another @samp{/}, the function discards everything before it (up |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2059 through the immediately preceding @samp{/}). |
6555 | 2060 |
2061 @example | |
2062 @group | |
2063 (substitute-in-file-name "bar/~/foo") | |
2064 @result{} "~/foo" | |
2065 @end group | |
2066 @group | |
2067 (substitute-in-file-name "/usr/local/$HOME/foo") | |
2068 @result{} "/xcssun/users/rms/foo" | |
21007
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
2069 ;; @r{@file{/usr/local/} has been discarded.} |
6555 | 2070 @end group |
2071 @end example | |
2072 | |
2073 On VMS, @samp{$} substitution is not done, so this function does nothing | |
2074 on VMS except discard superfluous initial components as shown above. | |
2075 @end defun | |
2076 | |
2077 @node Unique File Names | |
2078 @subsection Generating Unique File Names | |
2079 | |
2080 Some programs need to write temporary files. Here is the usual way to | |
60444
78a2cd972ba1
(Writing to Files): Get rid of "Emacs 21".
Richard M. Stallman <rms@gnu.org>
parents:
59877
diff
changeset
|
2081 construct a name for such a file: |
25751
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2082 |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2083 @example |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2084 (make-temp-file @var{name-of-application}) |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2085 @end example |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2086 |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2087 @noindent |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2088 The job of @code{make-temp-file} is to prevent two different users or |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2089 two different jobs from trying to use the exact same file name. |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2090 |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2091 @defun make-temp-file prefix &optional dir-flag suffix |
25751
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2092 @tindex make-temp-file |
61795
8757023049af
(Unique File Names): Don't mention "numbers" in the documentation
Eli Zaretskii <eliz@gnu.org>
parents:
61793
diff
changeset
|
2093 This function creates a temporary file and returns its name. Emacs |
8757023049af
(Unique File Names): Don't mention "numbers" in the documentation
Eli Zaretskii <eliz@gnu.org>
parents:
61793
diff
changeset
|
2094 creates the temporary file's name by adding to @var{prefix} some |
8757023049af
(Unique File Names): Don't mention "numbers" in the documentation
Eli Zaretskii <eliz@gnu.org>
parents:
61793
diff
changeset
|
2095 random characters that are different in each Emacs job. The result is |
8757023049af
(Unique File Names): Don't mention "numbers" in the documentation
Eli Zaretskii <eliz@gnu.org>
parents:
61793
diff
changeset
|
2096 guaranteed to be a newly created empty file. On MS-DOS, this function |
8757023049af
(Unique File Names): Don't mention "numbers" in the documentation
Eli Zaretskii <eliz@gnu.org>
parents:
61793
diff
changeset
|
2097 can truncate the @var{string} prefix to fit into the 8+3 file-name |
8757023049af
(Unique File Names): Don't mention "numbers" in the documentation
Eli Zaretskii <eliz@gnu.org>
parents:
61793
diff
changeset
|
2098 limits. If @var{prefix} is a relative file name, it is expanded |
8757023049af
(Unique File Names): Don't mention "numbers" in the documentation
Eli Zaretskii <eliz@gnu.org>
parents:
61793
diff
changeset
|
2099 against @code{temporary-file-directory}. |
25751
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2100 |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2101 @example |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2102 @group |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2103 (make-temp-file "foo") |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2104 @result{} "/tmp/foo232J6v" |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2105 @end group |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2106 @end example |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2107 |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2108 When @code{make-temp-file} returns, the file has been created and is |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2109 empty. At that point, you should write the intended contents into the |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2110 file. |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2111 |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2112 If @var{dir-flag} is non-@code{nil}, @code{make-temp-file} creates an |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2113 empty directory instead of an empty file. It returns the file name, |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2114 not the directory name, of that directory. @xref{Directory Names}. |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2115 |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2116 If @var{suffix} is non-@code{nil}, @code{make-temp-file} adds it at |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2117 the end of the file name. |
25751
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2118 |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2119 To prevent conflicts among different libraries running in the same |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2120 Emacs, each Lisp program that uses @code{make-temp-file} should have its |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2121 own @var{prefix}. The number added to the end of @var{prefix} |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2122 distinguishes between the same application running in different Emacs |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2123 jobs. Additional added characters permit a large number of distinct |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2124 names even in one Emacs job. |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2125 @end defun |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2126 |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2127 The default directory for temporary files is controlled by the |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2128 variable @code{temporary-file-directory}. This variable gives the user |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2129 a uniform way to specify the directory for all temporary files. Some |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2130 programs use @code{small-temporary-file-directory} instead, if that is |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2131 non-@code{nil}. To use it, you should expand the prefix against |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2132 the proper directory before calling @code{make-temp-file}. |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2133 |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2134 In older Emacs versions where @code{make-temp-file} does not exist, |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2135 you should use @code{make-temp-name} instead: |
6555 | 2136 |
2137 @example | |
21007
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
2138 (make-temp-name |
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
2139 (expand-file-name @var{name-of-application} |
22138
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
2140 temporary-file-directory)) |
6555 | 2141 @end example |
2142 | |
2143 @defun make-temp-name string | |
61795
8757023049af
(Unique File Names): Don't mention "numbers" in the documentation
Eli Zaretskii <eliz@gnu.org>
parents:
61793
diff
changeset
|
2144 This function generates a string that can be used as a unique file |
8757023049af
(Unique File Names): Don't mention "numbers" in the documentation
Eli Zaretskii <eliz@gnu.org>
parents:
61793
diff
changeset
|
2145 name. The name starts with @var{string}, and has several random |
8757023049af
(Unique File Names): Don't mention "numbers" in the documentation
Eli Zaretskii <eliz@gnu.org>
parents:
61793
diff
changeset
|
2146 characters appended to it, which are different in each Emacs job. It |
8757023049af
(Unique File Names): Don't mention "numbers" in the documentation
Eli Zaretskii <eliz@gnu.org>
parents:
61793
diff
changeset
|
2147 is like @code{make-temp-file} except that it just constructs a name, |
8757023049af
(Unique File Names): Don't mention "numbers" in the documentation
Eli Zaretskii <eliz@gnu.org>
parents:
61793
diff
changeset
|
2148 and does not create a file. Another difference is that @var{string} |
8757023049af
(Unique File Names): Don't mention "numbers" in the documentation
Eli Zaretskii <eliz@gnu.org>
parents:
61793
diff
changeset
|
2149 should be an absolute file name. On MS-DOS, this function can |
8757023049af
(Unique File Names): Don't mention "numbers" in the documentation
Eli Zaretskii <eliz@gnu.org>
parents:
61793
diff
changeset
|
2150 truncate the @var{string} prefix to fit into the 8+3 file-name limits. |
6555 | 2151 @end defun |
2152 | |
22138
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
2153 @defvar temporary-file-directory |
25751
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2154 @cindex @code{TMPDIR} environment variable |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2155 @cindex @code{TMP} environment variable |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2156 @cindex @code{TEMP} environment variable |
22138
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
2157 This variable specifies the directory name for creating temporary files. |
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
2158 Its value should be a directory name (@pxref{Directory Names}), but it |
22271
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
2159 is good for Lisp programs to cope if the value is a directory's file |
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
2160 name instead. Using the value as the second argument to |
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
2161 @code{expand-file-name} is a good way to achieve that. |
22138
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
2162 |
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
2163 The default value is determined in a reasonable way for your operating |
25751
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2164 system; it is based on the @code{TMPDIR}, @code{TMP} and @code{TEMP} |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2165 environment variables, with a fall-back to a system-dependent name if |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2166 none of these variables is defined. |
22138
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
2167 |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2168 Even if you do not use @code{make-temp-file} to create the temporary |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2169 file, you should still use this variable to decide which directory to |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2170 put the file in. However, if you expect the file to be small, you |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2171 should use @code{small-temporary-file-directory} first if that is |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2172 non-@code{nil}. |
25751
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2173 @end defvar |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2174 |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2175 @tindex small-temporary-file-directory |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2176 @defvar small-temporary-file-directory |
60444
78a2cd972ba1
(Writing to Files): Get rid of "Emacs 21".
Richard M. Stallman <rms@gnu.org>
parents:
59877
diff
changeset
|
2177 This variable specifies the directory name for |
25751
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2178 creating certain temporary files, which are likely to be small. |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2179 |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2180 If you want to write a temporary file which is likely to be small, you |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2181 should compute the directory like this: |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2182 |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2183 @example |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2184 (make-temp-file |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2185 (expand-file-name @var{prefix} |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2186 (or small-temporary-file-directory |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2187 temporary-file-directory))) |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2188 @end example |
22138
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
2189 @end defvar |
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
2190 |
6555 | 2191 @node File Name Completion |
2192 @subsection File Name Completion | |
2193 @cindex file name completion subroutines | |
2194 @cindex completion, file name | |
2195 | |
2196 This section describes low-level subroutines for completing a file | |
2197 name. For other completion functions, see @ref{Completion}. | |
2198 | |
2199 @defun file-name-all-completions partial-filename directory | |
2200 This function returns a list of all possible completions for a file | |
2201 whose name starts with @var{partial-filename} in directory | |
2202 @var{directory}. The order of the completions is the order of the files | |
2203 in the directory, which is unpredictable and conveys no useful | |
2204 information. | |
2205 | |
2206 The argument @var{partial-filename} must be a file name containing no | |
28635
cda2b6ed6aec
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
28608
diff
changeset
|
2207 directory part and no slash (or backslash on some systems). The current |
cda2b6ed6aec
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
28608
diff
changeset
|
2208 buffer's default directory is prepended to @var{directory}, if |
cda2b6ed6aec
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
28608
diff
changeset
|
2209 @var{directory} is not absolute. |
6555 | 2210 |
16736
981e116b4ac6
Minor cleanups for overfull hboxes.
Richard M. Stallman <rms@gnu.org>
parents:
15913
diff
changeset
|
2211 In the following example, suppose that @file{~rms/lewis} is the current |
981e116b4ac6
Minor cleanups for overfull hboxes.
Richard M. Stallman <rms@gnu.org>
parents:
15913
diff
changeset
|
2212 default directory, and has five files whose names begin with @samp{f}: |
6555 | 2213 @file{foo}, @file{file~}, @file{file.c}, @file{file.c.~1~}, and |
2214 @file{file.c.~2~}.@refill | |
2215 | |
2216 @example | |
2217 @group | |
2218 (file-name-all-completions "f" "") | |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
47980
diff
changeset
|
2219 @result{} ("foo" "file~" "file.c.~2~" |
6555 | 2220 "file.c.~1~" "file.c") |
2221 @end group | |
2222 | |
2223 @group | |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
47980
diff
changeset
|
2224 (file-name-all-completions "fo" "") |
6555 | 2225 @result{} ("foo") |
2226 @end group | |
2227 @end example | |
2228 @end defun | |
2229 | |
2230 @defun file-name-completion filename directory | |
2231 This function completes the file name @var{filename} in directory | |
2232 @var{directory}. It returns the longest prefix common to all file names | |
2233 in directory @var{directory} that start with @var{filename}. | |
2234 | |
2235 If only one match exists and @var{filename} matches it exactly, the | |
2236 function returns @code{t}. The function returns @code{nil} if directory | |
2237 @var{directory} contains no name starting with @var{filename}. | |
2238 | |
2239 In the following example, suppose that the current default directory | |
2240 has five files whose names begin with @samp{f}: @file{foo}, | |
2241 @file{file~}, @file{file.c}, @file{file.c.~1~}, and | |
2242 @file{file.c.~2~}.@refill | |
2243 | |
2244 @example | |
2245 @group | |
2246 (file-name-completion "fi" "") | |
2247 @result{} "file" | |
2248 @end group | |
2249 | |
2250 @group | |
2251 (file-name-completion "file.c.~1" "") | |
2252 @result{} "file.c.~1~" | |
2253 @end group | |
2254 | |
2255 @group | |
2256 (file-name-completion "file.c.~1~" "") | |
2257 @result{} t | |
2258 @end group | |
2259 | |
2260 @group | |
2261 (file-name-completion "file.c.~3" "") | |
2262 @result{} nil | |
2263 @end group | |
2264 @end example | |
2265 @end defun | |
2266 | |
2267 @defopt completion-ignored-extensions | |
2268 @code{file-name-completion} usually ignores file names that end in any | |
2269 string in this list. It does not ignore them when all the possible | |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2270 completions end in one of these suffixes. This variable has no effect |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2271 on @code{file-name-all-completions}.@refill |
6555 | 2272 |
2273 A typical value might look like this: | |
2274 | |
2275 @example | |
2276 @group | |
2277 completion-ignored-extensions | |
2278 @result{} (".o" ".elc" "~" ".dvi") | |
2279 @end group | |
2280 @end example | |
39883
416c492df7c3
(File Name Completion): Document the significance of
Eli Zaretskii <eliz@gnu.org>
parents:
39296
diff
changeset
|
2281 |
416c492df7c3
(File Name Completion): Document the significance of
Eli Zaretskii <eliz@gnu.org>
parents:
39296
diff
changeset
|
2282 If an element of @code{completion-ignored-extensions} ends in a slash |
416c492df7c3
(File Name Completion): Document the significance of
Eli Zaretskii <eliz@gnu.org>
parents:
39296
diff
changeset
|
2283 @samp{/}, it signals a directory. The elements which do @emph{not} end |
416c492df7c3
(File Name Completion): Document the significance of
Eli Zaretskii <eliz@gnu.org>
parents:
39296
diff
changeset
|
2284 in a slash will never match a directory; thus, the above value will not |
416c492df7c3
(File Name Completion): Document the significance of
Eli Zaretskii <eliz@gnu.org>
parents:
39296
diff
changeset
|
2285 filter out a directory named @file{foo.elc}. |
6555 | 2286 @end defopt |
2287 | |
15765
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2288 @node Standard File Names |
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2289 @subsection Standard File Names |
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2290 |
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2291 Most of the file names used in Lisp programs are entered by the user. |
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2292 But occasionally a Lisp program needs to specify a standard file name |
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2293 for a particular use---typically, to hold customization information |
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2294 about each user. For example, abbrev definitions are stored (by |
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2295 default) in the file @file{~/.abbrev_defs}; the @code{completion} |
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2296 package stores completions in the file @file{~/.completions}. These are |
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2297 two of the many standard file names used by parts of Emacs for certain |
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2298 purposes. |
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2299 |
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2300 Various operating systems have their own conventions for valid file |
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2301 names and for which file names to use for user profile data. A Lisp |
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2302 program which reads a file using a standard file name ought to use, on |
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2303 each type of system, a file name suitable for that system. The function |
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2304 @code{convert-standard-filename} makes this easy to do. |
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2305 |
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2306 @defun convert-standard-filename filename |
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2307 This function alters the file name @var{filename} to fit the conventions |
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2308 of the operating system in use, and returns the result as a new string. |
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2309 @end defun |
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2310 |
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2311 The recommended way to specify a standard file name in a Lisp program |
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2312 is to choose a name which fits the conventions of GNU and Unix systems, |
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2313 usually with a nondirectory part that starts with a period, and pass it |
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2314 to @code{convert-standard-filename} instead of using it directly. Here |
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2315 is an example from the @code{completion} package: |
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2316 |
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2317 @example |
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2318 (defvar save-completions-file-name |
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2319 (convert-standard-filename "~/.completions") |
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2320 "*The file name to save completions to.") |
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2321 @end example |
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2322 |
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2323 On GNU and Unix systems, and on some other systems as well, |
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2324 @code{convert-standard-filename} returns its argument unchanged. On |
22138
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
2325 some other systems, it alters the name to fit the system's conventions. |
15765
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2326 |
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2327 For example, on MS-DOS the alterations made by this function include |
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2328 converting a leading @samp{.} to @samp{_}, converting a @samp{_} in the |
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2329 middle of the name to @samp{.} if there is no other @samp{.}, inserting |
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2330 a @samp{.} after eight characters if there is none, and truncating to |
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2331 three characters after the @samp{.}. (It makes other changes as well.) |
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2332 Thus, @file{.abbrev_defs} becomes @file{_abbrev.def}, and |
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2333 @file{.completions} becomes @file{_complet.ion}. |
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2334 |
6555 | 2335 @node Contents of Directories |
2336 @section Contents of Directories | |
2337 @cindex directory-oriented functions | |
2338 @cindex file names in directory | |
2339 | |
2340 A directory is a kind of file that contains other files entered under | |
2341 various names. Directories are a feature of the file system. | |
2342 | |
2343 Emacs can list the names of the files in a directory as a Lisp list, | |
2344 or display the names in a buffer using the @code{ls} shell command. In | |
2345 the latter case, it can optionally display information about each file, | |
2346 depending on the options passed to the @code{ls} command. | |
2347 | |
2348 @defun directory-files directory &optional full-name match-regexp nosort | |
2349 This function returns a list of the names of the files in the directory | |
2350 @var{directory}. By default, the list is in alphabetical order. | |
2351 | |
2352 If @var{full-name} is non-@code{nil}, the function returns the files' | |
2353 absolute file names. Otherwise, it returns the names relative to | |
2354 the specified directory. | |
2355 | |
2356 If @var{match-regexp} is non-@code{nil}, this function returns only | |
2357 those file names that contain a match for that regular expression---the | |
2358 other file names are excluded from the list. | |
2359 | |
2360 @c Emacs 19 feature | |
2361 If @var{nosort} is non-@code{nil}, @code{directory-files} does not sort | |
2362 the list, so you get the file names in no particular order. Use this if | |
2363 you want the utmost possible speed and don't care what order the files | |
2364 are processed in. If the order of processing is visible to the user, | |
2365 then the user will probably be happier if you do sort the names. | |
2366 | |
2367 @example | |
2368 @group | |
2369 (directory-files "~lewis") | |
2370 @result{} ("#foo#" "#foo.el#" "." ".." | |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
47980
diff
changeset
|
2371 "dired-mods.el" "files.texi" |
6555 | 2372 "files.texi.~1~") |
2373 @end group | |
2374 @end example | |
2375 | |
2376 An error is signaled if @var{directory} is not the name of a directory | |
2377 that can be read. | |
2378 @end defun | |
2379 | |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2380 @defun directory-files-and-attributes directory &optional full-name match-regexp nosort id-format |
53425
bd30a9882e31
(Contents of Directories):
Richard M. Stallman <rms@gnu.org>
parents:
53109
diff
changeset
|
2381 This is similar to @code{directory-files} in deciding which files |
bd30a9882e31
(Contents of Directories):
Richard M. Stallman <rms@gnu.org>
parents:
53109
diff
changeset
|
2382 to report on and how to report their names. However, instead |
bd30a9882e31
(Contents of Directories):
Richard M. Stallman <rms@gnu.org>
parents:
53109
diff
changeset
|
2383 of returning a list of file names, it returns for each file a |
bd30a9882e31
(Contents of Directories):
Richard M. Stallman <rms@gnu.org>
parents:
53109
diff
changeset
|
2384 list @code{(@var{filename} . @var{attributes})}, where @var{attributes} |
bd30a9882e31
(Contents of Directories):
Richard M. Stallman <rms@gnu.org>
parents:
53109
diff
changeset
|
2385 is what @code{file-attributes} would return for that file. |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2386 The optional argument @var{id-format} has the same meaning as the |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2387 corresponding argument to @code{file-attributes} (@pxref{Definition |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2388 of file-attributes}). |
53425
bd30a9882e31
(Contents of Directories):
Richard M. Stallman <rms@gnu.org>
parents:
53109
diff
changeset
|
2389 @end defun |
bd30a9882e31
(Contents of Directories):
Richard M. Stallman <rms@gnu.org>
parents:
53109
diff
changeset
|
2390 |
6555 | 2391 @defun file-name-all-versions file dirname |
2392 This function returns a list of all versions of the file named | |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2393 @var{file} in directory @var{dirname}. It is only available on VMS. |
6555 | 2394 @end defun |
2395 | |
24951
7451b1458af1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22271
diff
changeset
|
2396 @tindex file-expand-wildcards |
7451b1458af1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22271
diff
changeset
|
2397 @defun file-expand-wildcards pattern &optional full |
7451b1458af1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22271
diff
changeset
|
2398 This function expands the wildcard pattern @var{pattern}, returning |
24952 | 2399 a list of file names that match it. |
24951
7451b1458af1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22271
diff
changeset
|
2400 |
24952 | 2401 If @var{pattern} is written as an absolute file name, |
24951
7451b1458af1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22271
diff
changeset
|
2402 the values are absolute also. |
7451b1458af1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22271
diff
changeset
|
2403 |
7451b1458af1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22271
diff
changeset
|
2404 If @var{pattern} is written as a relative file name, it is interpreted |
7451b1458af1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22271
diff
changeset
|
2405 relative to the current default directory. The file names returned are |
7451b1458af1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22271
diff
changeset
|
2406 normally also relative to the current default directory. However, if |
7451b1458af1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22271
diff
changeset
|
2407 @var{full} is non-@code{nil}, they are absolute. |
7451b1458af1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22271
diff
changeset
|
2408 @end defun |
7451b1458af1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22271
diff
changeset
|
2409 |
6555 | 2410 @defun insert-directory file switches &optional wildcard full-directory-p |
7735
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
2411 This function inserts (in the current buffer) a directory listing for |
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
2412 directory @var{file}, formatted with @code{ls} according to |
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
2413 @var{switches}. It leaves point after the inserted text. |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2414 @var{switches} may be a string of options, or a list of strings |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2415 representing individual options. |
6555 | 2416 |
7735
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
2417 The argument @var{file} may be either a directory name or a file |
6555 | 2418 specification including wildcard characters. If @var{wildcard} is |
2419 non-@code{nil}, that means treat @var{file} as a file specification with | |
2420 wildcards. | |
2421 | |
22138
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
2422 If @var{full-directory-p} is non-@code{nil}, that means the directory |
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
2423 listing is expected to show the full contents of a directory. You |
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
2424 should specify @code{t} when @var{file} is a directory and switches do |
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
2425 not contain @samp{-d}. (The @samp{-d} option to @code{ls} says to |
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
2426 describe a directory itself as a file, rather than showing its |
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
2427 contents.) |
6555 | 2428 |
25751
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2429 On most systems, this function works by running a directory listing |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2430 program whose name is in the variable @code{insert-directory-program}. |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2431 If @var{wildcard} is non-@code{nil}, it also runs the shell specified by |
6555 | 2432 @code{shell-file-name}, to expand the wildcards. |
25751
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2433 |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2434 MS-DOS and MS-Windows systems usually lack the standard Unix program |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2435 @code{ls}, so this function emulates the standard Unix program @code{ls} |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2436 with Lisp code. |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2437 |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2438 As a technical detail, when @var{switches} contains the long |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2439 @samp{--dired} option, @code{insert-directory} treats it specially, |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2440 for the sake of dired. However, the normally equivalent short |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2441 @samp{-D} option is just passed on to @code{insert-directory-program}, |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2442 as any other option. |
6555 | 2443 @end defun |
2444 | |
2445 @defvar insert-directory-program | |
2446 This variable's value is the program to run to generate a directory listing | |
25751
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2447 for the function @code{insert-directory}. It is ignored on systems |
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2448 which generate the listing with Lisp code. |
6555 | 2449 @end defvar |
2450 | |
2451 @node Create/Delete Dirs | |
2452 @section Creating and Deleting Directories | |
2453 @c Emacs 19 features | |
2454 | |
7735
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
2455 Most Emacs Lisp file-manipulation functions get errors when used on |
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
2456 files that are directories. For example, you cannot delete a directory |
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
2457 with @code{delete-file}. These special functions exist to create and |
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
2458 delete directories. |
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
2459 |
26696
ef5e7bbe6f19
Current version from /gd/gnu/elisp.
Dave Love <fx@gnu.org>
parents:
25751
diff
changeset
|
2460 @defun make-directory dirname &optional parents |
6555 | 2461 This function creates a directory named @var{dirname}. |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2462 If @var{parents} is non-@code{nil}, as is always the case in an |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2463 interactive call, that means to create the parent directories first, |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2464 if they don't already exist. |
6555 | 2465 @end defun |
2466 | |
2467 @defun delete-directory dirname | |
2468 This function deletes the directory named @var{dirname}. The function | |
2469 @code{delete-file} does not work for files that are directories; you | |
12098 | 2470 must use @code{delete-directory} for them. If the directory contains |
2471 any files, @code{delete-directory} signals an error. | |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2472 |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2473 This function only follows symbolic links at the level of parent |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2474 directories. |
6555 | 2475 @end defun |
2476 | |
2477 @node Magic File Names | |
2478 @section Making Certain File Names ``Magic'' | |
2479 @cindex magic file names | |
2480 | |
2481 @c Emacs 19 feature | |
21007
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
2482 You can implement special handling for certain file names. This is |
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
2483 called making those names @dfn{magic}. The principal use for this |
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
2484 feature is in implementing remote file names (@pxref{Remote Files,, |
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
2485 Remote Files, emacs, The GNU Emacs Manual}). |
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
2486 |
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
2487 To define a kind of magic file name, you must supply a regular |
7735
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
2488 expression to define the class of names (all those that match the |
6555 | 2489 regular expression), plus a handler that implements all the primitive |
2490 Emacs file operations for file names that do match. | |
2491 | |
21007
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
2492 The variable @code{file-name-handler-alist} holds a list of handlers, |
6555 | 2493 together with regular expressions that determine when to apply each |
2494 handler. Each element has this form: | |
2495 | |
2496 @example | |
2497 (@var{regexp} . @var{handler}) | |
2498 @end example | |
2499 | |
2500 @noindent | |
2501 All the Emacs primitives for file access and file name transformation | |
2502 check the given file name against @code{file-name-handler-alist}. If | |
2503 the file name matches @var{regexp}, the primitives handle that file by | |
2504 calling @var{handler}. | |
2505 | |
61949
d0cfb9c978f9
(Magic File Names): Document `operations' property.
Richard M. Stallman <rms@gnu.org>
parents:
61795
diff
changeset
|
2506 The first argument given to @var{handler} is the name of the |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2507 primitive, as a symbol; the remaining arguments are the arguments that |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2508 were passed to that primitive. (The first of these arguments is most |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2509 often the file name itself.) For example, if you do this: |
6555 | 2510 |
2511 @example | |
2512 (file-exists-p @var{filename}) | |
2513 @end example | |
2514 | |
2515 @noindent | |
2516 and @var{filename} has handler @var{handler}, then @var{handler} is | |
2517 called like this: | |
2518 | |
2519 @example | |
2520 (funcall @var{handler} 'file-exists-p @var{filename}) | |
2521 @end example | |
2522 | |
61949
d0cfb9c978f9
(Magic File Names): Document `operations' property.
Richard M. Stallman <rms@gnu.org>
parents:
61795
diff
changeset
|
2523 When a function takes two or more arguments that must be file names, |
37582
fdf780ddf0ae
Explain how handler is called, for magic file operations that take
Richard M. Stallman <rms@gnu.org>
parents:
32859
diff
changeset
|
2524 it checks each of those names for a handler. For example, if you do |
fdf780ddf0ae
Explain how handler is called, for magic file operations that take
Richard M. Stallman <rms@gnu.org>
parents:
32859
diff
changeset
|
2525 this: |
fdf780ddf0ae
Explain how handler is called, for magic file operations that take
Richard M. Stallman <rms@gnu.org>
parents:
32859
diff
changeset
|
2526 |
fdf780ddf0ae
Explain how handler is called, for magic file operations that take
Richard M. Stallman <rms@gnu.org>
parents:
32859
diff
changeset
|
2527 @example |
fdf780ddf0ae
Explain how handler is called, for magic file operations that take
Richard M. Stallman <rms@gnu.org>
parents:
32859
diff
changeset
|
2528 (expand-file-name @var{filename} @var{dirname}) |
fdf780ddf0ae
Explain how handler is called, for magic file operations that take
Richard M. Stallman <rms@gnu.org>
parents:
32859
diff
changeset
|
2529 @end example |
fdf780ddf0ae
Explain how handler is called, for magic file operations that take
Richard M. Stallman <rms@gnu.org>
parents:
32859
diff
changeset
|
2530 |
fdf780ddf0ae
Explain how handler is called, for magic file operations that take
Richard M. Stallman <rms@gnu.org>
parents:
32859
diff
changeset
|
2531 @noindent |
fdf780ddf0ae
Explain how handler is called, for magic file operations that take
Richard M. Stallman <rms@gnu.org>
parents:
32859
diff
changeset
|
2532 then it checks for a handler for @var{filename} and then for a handler |
fdf780ddf0ae
Explain how handler is called, for magic file operations that take
Richard M. Stallman <rms@gnu.org>
parents:
32859
diff
changeset
|
2533 for @var{dirname}. In either case, the @var{handler} is called like |
fdf780ddf0ae
Explain how handler is called, for magic file operations that take
Richard M. Stallman <rms@gnu.org>
parents:
32859
diff
changeset
|
2534 this: |
fdf780ddf0ae
Explain how handler is called, for magic file operations that take
Richard M. Stallman <rms@gnu.org>
parents:
32859
diff
changeset
|
2535 |
fdf780ddf0ae
Explain how handler is called, for magic file operations that take
Richard M. Stallman <rms@gnu.org>
parents:
32859
diff
changeset
|
2536 @example |
fdf780ddf0ae
Explain how handler is called, for magic file operations that take
Richard M. Stallman <rms@gnu.org>
parents:
32859
diff
changeset
|
2537 (funcall @var{handler} 'expand-file-name @var{filename} @var{dirname}) |
fdf780ddf0ae
Explain how handler is called, for magic file operations that take
Richard M. Stallman <rms@gnu.org>
parents:
32859
diff
changeset
|
2538 @end example |
fdf780ddf0ae
Explain how handler is called, for magic file operations that take
Richard M. Stallman <rms@gnu.org>
parents:
32859
diff
changeset
|
2539 |
fdf780ddf0ae
Explain how handler is called, for magic file operations that take
Richard M. Stallman <rms@gnu.org>
parents:
32859
diff
changeset
|
2540 @noindent |
fdf780ddf0ae
Explain how handler is called, for magic file operations that take
Richard M. Stallman <rms@gnu.org>
parents:
32859
diff
changeset
|
2541 The @var{handler} then needs to figure out whether to handle |
fdf780ddf0ae
Explain how handler is called, for magic file operations that take
Richard M. Stallman <rms@gnu.org>
parents:
32859
diff
changeset
|
2542 @var{filename} or @var{dirname}. |
fdf780ddf0ae
Explain how handler is called, for magic file operations that take
Richard M. Stallman <rms@gnu.org>
parents:
32859
diff
changeset
|
2543 |
61949
d0cfb9c978f9
(Magic File Names): Document `operations' property.
Richard M. Stallman <rms@gnu.org>
parents:
61795
diff
changeset
|
2544 If the specified file name matches more than one handler, the one |
51913
3abc365e9d90
(Changing Files): copy-file allows dir as NEWNAME.
Richard M. Stallman <rms@gnu.org>
parents:
51793
diff
changeset
|
2545 whose match starts last in the file name gets precedence. This rule |
3abc365e9d90
(Changing Files): copy-file allows dir as NEWNAME.
Richard M. Stallman <rms@gnu.org>
parents:
51793
diff
changeset
|
2546 is chosen so that handlers for jobs such as uncompression are handled |
3abc365e9d90
(Changing Files): copy-file allows dir as NEWNAME.
Richard M. Stallman <rms@gnu.org>
parents:
51793
diff
changeset
|
2547 first, before handlers for jobs such as remote file access. |
3abc365e9d90
(Changing Files): copy-file allows dir as NEWNAME.
Richard M. Stallman <rms@gnu.org>
parents:
51793
diff
changeset
|
2548 |
7735
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
2549 Here are the operations that a magic file name handler gets to handle: |
6555 | 2550 |
27193 | 2551 @ifnottex |
6555 | 2552 @noindent |
47980
5492d1831d2a
From Michael Albinus.
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
47514
diff
changeset
|
2553 @code{access-file}, @code{add-name-to-file}, |
5492d1831d2a
From Michael Albinus.
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
47514
diff
changeset
|
2554 @code{byte-compiler-base-file-name},@* |
5492d1831d2a
From Michael Albinus.
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
47514
diff
changeset
|
2555 @code{copy-file}, @code{delete-directory}, |
21682
90da2489c498
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21007
diff
changeset
|
2556 @code{delete-file}, |
12226 | 2557 @code{diff-latest-backup-file}, |
6555 | 2558 @code{directory-file-name}, |
21682
90da2489c498
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21007
diff
changeset
|
2559 @code{directory-files}, |
47980
5492d1831d2a
From Michael Albinus.
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
47514
diff
changeset
|
2560 @code{directory-files-and-attributes}, |
16736
981e116b4ac6
Minor cleanups for overfull hboxes.
Richard M. Stallman <rms@gnu.org>
parents:
15913
diff
changeset
|
2561 @code{dired-call-process}, |
47980
5492d1831d2a
From Michael Albinus.
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
47514
diff
changeset
|
2562 @code{dired-compress-file}, @code{dired-uncache},@* |
21682
90da2489c498
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21007
diff
changeset
|
2563 @code{expand-file-name}, |
47980
5492d1831d2a
From Michael Albinus.
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
47514
diff
changeset
|
2564 @code{file-accessible-directory-p}, |
21682
90da2489c498
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21007
diff
changeset
|
2565 @code{file-attributes}, |
90da2489c498
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21007
diff
changeset
|
2566 @code{file-directory-p}, |
47980
5492d1831d2a
From Michael Albinus.
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
47514
diff
changeset
|
2567 @code{file-executable-p}, @code{file-exists-p}, |
55847
d87f8236b6fd
files.texi (Magic File Names): Add `file-remote-p' as operation
Michael Albinus <michael.albinus@gmx.de>
parents:
55192
diff
changeset
|
2568 @code{file-local-copy}, @code{file-remote-p}, |
47980
5492d1831d2a
From Michael Albinus.
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
47514
diff
changeset
|
2569 @code{file-modes}, @code{file-name-all-completions}, |
21682
90da2489c498
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21007
diff
changeset
|
2570 @code{file-name-as-directory}, |
90da2489c498
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21007
diff
changeset
|
2571 @code{file-name-completion}, |
16736
981e116b4ac6
Minor cleanups for overfull hboxes.
Richard M. Stallman <rms@gnu.org>
parents:
15913
diff
changeset
|
2572 @code{file-name-directory}, |
981e116b4ac6
Minor cleanups for overfull hboxes.
Richard M. Stallman <rms@gnu.org>
parents:
15913
diff
changeset
|
2573 @code{file-name-nondirectory}, |
6555 | 2574 @code{file-name-sans-versions}, @code{file-newer-than-file-p}, |
15765
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2575 @code{file-ownership-preserved-p}, |
11626
0b86aef0c387
Mention file-regular-p operation.
Richard M. Stallman <rms@gnu.org>
parents:
8364
diff
changeset
|
2576 @code{file-readable-p}, @code{file-regular-p}, @code{file-symlink-p}, |
12226 | 2577 @code{file-truename}, @code{file-writable-p}, |
15765
8cc15b664c4c
New node Standard File Names.
Richard M. Stallman <rms@gnu.org>
parents:
14152
diff
changeset
|
2578 @code{find-backup-file-name}, |
47980
5492d1831d2a
From Michael Albinus.
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
47514
diff
changeset
|
2579 @code{find-file-noselect},@* |
5492d1831d2a
From Michael Albinus.
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
47514
diff
changeset
|
2580 @code{get-file-buffer}, |
21682
90da2489c498
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21007
diff
changeset
|
2581 @code{insert-directory}, |
47980
5492d1831d2a
From Michael Albinus.
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
47514
diff
changeset
|
2582 @code{insert-file-contents},@* |
65248
0f994edbec5e
Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents:
64889
diff
changeset
|
2583 @code{load}, |
0f994edbec5e
Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents:
64889
diff
changeset
|
2584 @code{make-auto-save-file-name}, |
0f994edbec5e
Make `make-auto-save-file-name' a magic operation.
Michael Albinus <michael.albinus@gmx.de>
parents:
64889
diff
changeset
|
2585 @code{make-directory}, |
47980
5492d1831d2a
From Michael Albinus.
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
47514
diff
changeset
|
2586 @code{make-directory-internal}, |
5492d1831d2a
From Michael Albinus.
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
47514
diff
changeset
|
2587 @code{make-symbolic-link},@* |
55192
dd5538a91d27
(Changing Files): Document set-file-times.
Eli Zaretskii <eliz@gnu.org>
parents:
54861
diff
changeset
|
2588 @code{rename-file}, @code{set-file-modes}, @code{set-file-times}, |
47980
5492d1831d2a
From Michael Albinus.
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
47514
diff
changeset
|
2589 @code{set-visited-file-modtime}, @code{shell-command}, |
5492d1831d2a
From Michael Albinus.
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
47514
diff
changeset
|
2590 @code{substitute-in-file-name},@* |
21682
90da2489c498
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21007
diff
changeset
|
2591 @code{unhandled-file-name-directory}, |
16736
981e116b4ac6
Minor cleanups for overfull hboxes.
Richard M. Stallman <rms@gnu.org>
parents:
15913
diff
changeset
|
2592 @code{vc-registered}, |
21682
90da2489c498
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21007
diff
changeset
|
2593 @code{verify-visited-file-modtime},@* |
90da2489c498
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21007
diff
changeset
|
2594 @code{write-region}. |
27193 | 2595 @end ifnottex |
22271
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
2596 @iftex |
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
2597 @noindent |
25751
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2598 @flushleft |
47980
5492d1831d2a
From Michael Albinus.
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
47514
diff
changeset
|
2599 @code{access-file}, @code{add-name-to-file}, |
5492d1831d2a
From Michael Albinus.
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
47514
diff
changeset
|
2600 @code{byte-com@discretionary{}{}{}piler-base-file-name}, |
5492d1831d2a
From Michael Albinus.
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
47514
diff
changeset
|
2601 @code{copy-file}, @code{delete-directory}, |
22271
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
2602 @code{delete-file}, |
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
2603 @code{diff-latest-backup-file}, |
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
2604 @code{directory-file-name}, |
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
2605 @code{directory-files}, |
47980
5492d1831d2a
From Michael Albinus.
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
47514
diff
changeset
|
2606 @code{directory-files-and-at@discretionary{}{}{}tributes}, |
22271
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
2607 @code{dired-call-process}, |
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
2608 @code{dired-compress-file}, @code{dired-uncache}, |
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
2609 @code{expand-file-name}, |
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
2610 @code{file-accessible-direc@discretionary{}{}{}tory-p}, |
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
2611 @code{file-attributes}, |
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
2612 @code{file-direct@discretionary{}{}{}ory-p}, |
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
2613 @code{file-executable-p}, @code{file-exists-p}, |
55847
d87f8236b6fd
files.texi (Magic File Names): Add `file-remote-p' as operation
Michael Albinus <michael.albinus@gmx.de>
parents:
55192
diff
changeset
|
2614 @code{file-local-copy}, @code{file-remote-p}, |
22271
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
2615 @code{file-modes}, @code{file-name-all-completions}, |
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
2616 @code{file-name-as-directory}, |
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
2617 @code{file-name-completion}, |
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
2618 @code{file-name-directory}, |
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
2619 @code{file-name-nondirec@discretionary{}{}{}tory}, |
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
2620 @code{file-name-sans-versions}, @code{file-newer-than-file-p}, |
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
2621 @code{file-ownership-pre@discretionary{}{}{}served-p}, |
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
2622 @code{file-readable-p}, @code{file-regular-p}, @code{file-symlink-p}, |
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
2623 @code{file-truename}, @code{file-writable-p}, |
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
2624 @code{find-backup-file-name}, |
47980
5492d1831d2a
From Michael Albinus.
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
47514
diff
changeset
|
2625 @code{find-file-noselect}, |
22271
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
2626 @code{get-file-buffer}, |
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
2627 @code{insert-directory}, |
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
2628 @code{insert-file-contents}, |
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
2629 @code{load}, @code{make-direc@discretionary{}{}{}tory}, |
47980
5492d1831d2a
From Michael Albinus.
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
47514
diff
changeset
|
2630 @code{make-direc@discretionary{}{}{}tory-internal}, |
5492d1831d2a
From Michael Albinus.
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
47514
diff
changeset
|
2631 @code{make-symbolic-link}, |
5492d1831d2a
From Michael Albinus.
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
47514
diff
changeset
|
2632 @code{rename-file}, @code{set-file-modes}, |
22271
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
2633 @code{set-visited-file-modtime}, @code{shell-command}, |
47980
5492d1831d2a
From Michael Albinus.
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
47514
diff
changeset
|
2634 @code{substitute-in-file-name}, |
22271
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
2635 @code{unhandled-file-name-directory}, |
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
2636 @code{vc-regis@discretionary{}{}{}tered}, |
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
2637 @code{verify-visited-file-modtime}, |
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
2638 @code{write-region}. |
25751
467b88fab665
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
24952
diff
changeset
|
2639 @end flushleft |
22271
71f954d59214
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
22138
diff
changeset
|
2640 @end iftex |
6555 | 2641 |
61949
d0cfb9c978f9
(Magic File Names): Document `operations' property.
Richard M. Stallman <rms@gnu.org>
parents:
61795
diff
changeset
|
2642 Handlers for @code{insert-file-contents} typically need to clear the |
8118
56b5ed321f8d
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7735
diff
changeset
|
2643 buffer's modified flag, with @code{(set-buffer-modified-p nil)}, if the |
56b5ed321f8d
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7735
diff
changeset
|
2644 @var{visit} argument is non-@code{nil}. This also has the effect of |
56b5ed321f8d
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7735
diff
changeset
|
2645 unlocking the buffer if it is locked. |
56b5ed321f8d
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7735
diff
changeset
|
2646 |
61949
d0cfb9c978f9
(Magic File Names): Document `operations' property.
Richard M. Stallman <rms@gnu.org>
parents:
61795
diff
changeset
|
2647 The handler function must handle all of the above operations, and |
7735
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
2648 possibly others to be added in the future. It need not implement all |
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
2649 these operations itself---when it has nothing special to do for a |
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
2650 certain operation, it can reinvoke the primitive, to handle the |
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
2651 operation ``in the usual way''. It should always reinvoke the primitive |
7db892210924
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
7088
diff
changeset
|
2652 for an operation it does not recognize. Here's one way to do this: |
6555 | 2653 |
7088
5a93e6fb43a4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
6555
diff
changeset
|
2654 @smallexample |
6555 | 2655 (defun my-file-handler (operation &rest args) |
2656 ;; @r{First check for the specific operations} | |
2657 ;; @r{that we have special handling for.} | |
2658 (cond ((eq operation 'insert-file-contents) @dots{}) | |
2659 ((eq operation 'write-region) @dots{}) | |
2660 @dots{} | |
2661 ;; @r{Handle any operation we don't know about.} | |
7088
5a93e6fb43a4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
6555
diff
changeset
|
2662 (t (let ((inhibit-file-name-handlers |
49600
23a1cea22d13
Trailing whitespace deleted.
Juanma Barranquero <lekktu@gmail.com>
parents:
47980
diff
changeset
|
2663 (cons 'my-file-handler |
21007
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
2664 (and (eq inhibit-file-name-operation operation) |
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
2665 inhibit-file-name-handlers))) |
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
2666 (inhibit-file-name-operation operation)) |
6555 | 2667 (apply operation args))))) |
7088
5a93e6fb43a4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
6555
diff
changeset
|
2668 @end smallexample |
6555 | 2669 |
61949
d0cfb9c978f9
(Magic File Names): Document `operations' property.
Richard M. Stallman <rms@gnu.org>
parents:
61795
diff
changeset
|
2670 When a handler function decides to call the ordinary Emacs primitive for |
7088
5a93e6fb43a4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
6555
diff
changeset
|
2671 the operation at hand, it needs to prevent the primitive from calling |
5a93e6fb43a4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
6555
diff
changeset
|
2672 the same handler once again, thus leading to an infinite recursion. The |
5a93e6fb43a4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
6555
diff
changeset
|
2673 example above shows how to do this, with the variables |
5a93e6fb43a4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
6555
diff
changeset
|
2674 @code{inhibit-file-name-handlers} and |
5a93e6fb43a4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
6555
diff
changeset
|
2675 @code{inhibit-file-name-operation}. Be careful to use them exactly as |
5a93e6fb43a4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
6555
diff
changeset
|
2676 shown above; the details are crucial for proper behavior in the case of |
5a93e6fb43a4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
6555
diff
changeset
|
2677 multiple handlers, and for operations that have two file names that may |
5a93e6fb43a4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
6555
diff
changeset
|
2678 each have handlers. |
5a93e6fb43a4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
6555
diff
changeset
|
2679 |
51020
417a9e80f335
(Magic File Names): Document the safe-magic property.
Richard M. Stallman <rms@gnu.org>
parents:
50501
diff
changeset
|
2680 @kindex safe-magic (@r{property}) |
61949
d0cfb9c978f9
(Magic File Names): Document `operations' property.
Richard M. Stallman <rms@gnu.org>
parents:
61795
diff
changeset
|
2681 Handlers that don't really do anything special for actual access to the |
51020
417a9e80f335
(Magic File Names): Document the safe-magic property.
Richard M. Stallman <rms@gnu.org>
parents:
50501
diff
changeset
|
2682 file---such as the ones that implement completion of host names for |
417a9e80f335
(Magic File Names): Document the safe-magic property.
Richard M. Stallman <rms@gnu.org>
parents:
50501
diff
changeset
|
2683 remote file names---should have a non-@code{nil} @code{safe-magic} |
417a9e80f335
(Magic File Names): Document the safe-magic property.
Richard M. Stallman <rms@gnu.org>
parents:
50501
diff
changeset
|
2684 property. For instance, Emacs normally ``protects'' directory names |
417a9e80f335
(Magic File Names): Document the safe-magic property.
Richard M. Stallman <rms@gnu.org>
parents:
50501
diff
changeset
|
2685 it finds in @code{PATH} from becoming magic, if they look like magic |
417a9e80f335
(Magic File Names): Document the safe-magic property.
Richard M. Stallman <rms@gnu.org>
parents:
50501
diff
changeset
|
2686 file names, by prefixing them with @samp{/:}. But if the handler that |
417a9e80f335
(Magic File Names): Document the safe-magic property.
Richard M. Stallman <rms@gnu.org>
parents:
50501
diff
changeset
|
2687 would be used for them has a non-@code{nil} @code{safe-magic} |
417a9e80f335
(Magic File Names): Document the safe-magic property.
Richard M. Stallman <rms@gnu.org>
parents:
50501
diff
changeset
|
2688 property, the @samp{/:} is not added. |
417a9e80f335
(Magic File Names): Document the safe-magic property.
Richard M. Stallman <rms@gnu.org>
parents:
50501
diff
changeset
|
2689 |
61949
d0cfb9c978f9
(Magic File Names): Document `operations' property.
Richard M. Stallman <rms@gnu.org>
parents:
61795
diff
changeset
|
2690 @kindex operations (@r{property}) |
d0cfb9c978f9
(Magic File Names): Document `operations' property.
Richard M. Stallman <rms@gnu.org>
parents:
61795
diff
changeset
|
2691 A file name handler can have an @code{operations} property to |
d0cfb9c978f9
(Magic File Names): Document `operations' property.
Richard M. Stallman <rms@gnu.org>
parents:
61795
diff
changeset
|
2692 declare which operations it handles in a nontrivial way. If this |
d0cfb9c978f9
(Magic File Names): Document `operations' property.
Richard M. Stallman <rms@gnu.org>
parents:
61795
diff
changeset
|
2693 property has a non-@code{nil} value, it should be a list of |
d0cfb9c978f9
(Magic File Names): Document `operations' property.
Richard M. Stallman <rms@gnu.org>
parents:
61795
diff
changeset
|
2694 operations; then only those operations will call the handler. This |
d0cfb9c978f9
(Magic File Names): Document `operations' property.
Richard M. Stallman <rms@gnu.org>
parents:
61795
diff
changeset
|
2695 avoids inefficiency, but its main purpose is for autoloaded handler |
d0cfb9c978f9
(Magic File Names): Document `operations' property.
Richard M. Stallman <rms@gnu.org>
parents:
61795
diff
changeset
|
2696 functions, so that they won't be loaded except when they have real |
d0cfb9c978f9
(Magic File Names): Document `operations' property.
Richard M. Stallman <rms@gnu.org>
parents:
61795
diff
changeset
|
2697 work to do. |
d0cfb9c978f9
(Magic File Names): Document `operations' property.
Richard M. Stallman <rms@gnu.org>
parents:
61795
diff
changeset
|
2698 |
7088
5a93e6fb43a4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
6555
diff
changeset
|
2699 @defvar inhibit-file-name-handlers |
5a93e6fb43a4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
6555
diff
changeset
|
2700 This variable holds a list of handlers whose use is presently inhibited |
5a93e6fb43a4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
6555
diff
changeset
|
2701 for a certain operation. |
5a93e6fb43a4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
6555
diff
changeset
|
2702 @end defvar |
5a93e6fb43a4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
6555
diff
changeset
|
2703 |
5a93e6fb43a4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
6555
diff
changeset
|
2704 @defvar inhibit-file-name-operation |
5a93e6fb43a4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
6555
diff
changeset
|
2705 The operation for which certain handlers are presently inhibited. |
5a93e6fb43a4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
6555
diff
changeset
|
2706 @end defvar |
5a93e6fb43a4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
6555
diff
changeset
|
2707 |
5a93e6fb43a4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
6555
diff
changeset
|
2708 @defun find-file-name-handler file operation |
6555 | 2709 This function returns the handler function for file name @var{file}, or |
7088
5a93e6fb43a4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
6555
diff
changeset
|
2710 @code{nil} if there is none. The argument @var{operation} should be the |
5a93e6fb43a4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
6555
diff
changeset
|
2711 operation to be performed on the file---the value you will pass to the |
5a93e6fb43a4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
6555
diff
changeset
|
2712 handler as its first argument when you call it. The operation is needed |
5a93e6fb43a4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
6555
diff
changeset
|
2713 for comparison with @code{inhibit-file-name-operation}. |
6555 | 2714 @end defun |
2715 | |
2716 @defun file-local-copy filename | |
52143
3b706f94b559
(Magic File Names): Add file-remote-p. Clarify file-local-copy.
Richard M. Stallman <rms@gnu.org>
parents:
52003
diff
changeset
|
2717 This function copies file @var{filename} to an ordinary non-magic file |
3b706f94b559
(Magic File Names): Add file-remote-p. Clarify file-local-copy.
Richard M. Stallman <rms@gnu.org>
parents:
52003
diff
changeset
|
2718 on the local machine, if it isn't on the local machine already. Magic |
3b706f94b559
(Magic File Names): Add file-remote-p. Clarify file-local-copy.
Richard M. Stallman <rms@gnu.org>
parents:
52003
diff
changeset
|
2719 file names should handle the @code{file-local-copy} operation if they |
3b706f94b559
(Magic File Names): Add file-remote-p. Clarify file-local-copy.
Richard M. Stallman <rms@gnu.org>
parents:
52003
diff
changeset
|
2720 refer to files on other machines. A magic file name that is used for |
3b706f94b559
(Magic File Names): Add file-remote-p. Clarify file-local-copy.
Richard M. Stallman <rms@gnu.org>
parents:
52003
diff
changeset
|
2721 other purposes than remote file access should not handle |
3b706f94b559
(Magic File Names): Add file-remote-p. Clarify file-local-copy.
Richard M. Stallman <rms@gnu.org>
parents:
52003
diff
changeset
|
2722 @code{file-local-copy}; then this function will treat the file as |
3b706f94b559
(Magic File Names): Add file-remote-p. Clarify file-local-copy.
Richard M. Stallman <rms@gnu.org>
parents:
52003
diff
changeset
|
2723 local. |
3b706f94b559
(Magic File Names): Add file-remote-p. Clarify file-local-copy.
Richard M. Stallman <rms@gnu.org>
parents:
52003
diff
changeset
|
2724 |
3b706f94b559
(Magic File Names): Add file-remote-p. Clarify file-local-copy.
Richard M. Stallman <rms@gnu.org>
parents:
52003
diff
changeset
|
2725 If @var{filename} is local, whether magic or not, this function does |
3b706f94b559
(Magic File Names): Add file-remote-p. Clarify file-local-copy.
Richard M. Stallman <rms@gnu.org>
parents:
52003
diff
changeset
|
2726 nothing and returns @code{nil}. Otherwise it returns the file name |
3b706f94b559
(Magic File Names): Add file-remote-p. Clarify file-local-copy.
Richard M. Stallman <rms@gnu.org>
parents:
52003
diff
changeset
|
2727 of the local copy file. |
3b706f94b559
(Magic File Names): Add file-remote-p. Clarify file-local-copy.
Richard M. Stallman <rms@gnu.org>
parents:
52003
diff
changeset
|
2728 @end defun |
3b706f94b559
(Magic File Names): Add file-remote-p. Clarify file-local-copy.
Richard M. Stallman <rms@gnu.org>
parents:
52003
diff
changeset
|
2729 |
3b706f94b559
(Magic File Names): Add file-remote-p. Clarify file-local-copy.
Richard M. Stallman <rms@gnu.org>
parents:
52003
diff
changeset
|
2730 @defun file-remote-p filename |
56322
f597c982349e
(Saving Buffers): Cleanup write-contents-function.
Richard M. Stallman <rms@gnu.org>
parents:
56321
diff
changeset
|
2731 This function tests whether @var{filename} is a remote file. If |
f597c982349e
(Saving Buffers): Cleanup write-contents-function.
Richard M. Stallman <rms@gnu.org>
parents:
56321
diff
changeset
|
2732 @var{filename} is local (not remote), the return value is @code{nil}. |
f597c982349e
(Saving Buffers): Cleanup write-contents-function.
Richard M. Stallman <rms@gnu.org>
parents:
56321
diff
changeset
|
2733 If @var{filename} is indeed remote, the return value is a string that |
f597c982349e
(Saving Buffers): Cleanup write-contents-function.
Richard M. Stallman <rms@gnu.org>
parents:
56321
diff
changeset
|
2734 identifies the remote system. |
f597c982349e
(Saving Buffers): Cleanup write-contents-function.
Richard M. Stallman <rms@gnu.org>
parents:
56321
diff
changeset
|
2735 |
63583
99e9892a51d9
Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents:
62856
diff
changeset
|
2736 This identifier string can include a host name and a user name, as |
99e9892a51d9
Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents:
62856
diff
changeset
|
2737 well as characters designating the method used to access the remote |
99e9892a51d9
Fix formatting ugliness.
Richard M. Stallman <rms@gnu.org>
parents:
62856
diff
changeset
|
2738 system. For example, the remote identifier string for the filename |
56322
f597c982349e
(Saving Buffers): Cleanup write-contents-function.
Richard M. Stallman <rms@gnu.org>
parents:
56321
diff
changeset
|
2739 @code{/ssh:user@@host:/some/file} is @code{/ssh:user@@host:}. |
56321
904bb1836ccd
(Magic File Names): `file-remote-p' returns an identifier of the
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
56231
diff
changeset
|
2740 |
904bb1836ccd
(Magic File Names): `file-remote-p' returns an identifier of the
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
56231
diff
changeset
|
2741 If @code{file-remote-p} returns the same identifier for two different |
56322
f597c982349e
(Saving Buffers): Cleanup write-contents-function.
Richard M. Stallman <rms@gnu.org>
parents:
56321
diff
changeset
|
2742 filenames, that means they are stored on the same file system and can |
56321
904bb1836ccd
(Magic File Names): `file-remote-p' returns an identifier of the
Kai Großjohann <kgrossjo@eu.uu.net>
parents:
56231
diff
changeset
|
2743 be accessed locally with respect to each other. This means, for |
56322
f597c982349e
(Saving Buffers): Cleanup write-contents-function.
Richard M. Stallman <rms@gnu.org>
parents:
56321
diff
changeset
|
2744 example, that it is possible to start a remote process accessing both |
f597c982349e
(Saving Buffers): Cleanup write-contents-function.
Richard M. Stallman <rms@gnu.org>
parents:
56321
diff
changeset
|
2745 files at the same time. Implementors of file handlers need to ensure |
f597c982349e
(Saving Buffers): Cleanup write-contents-function.
Richard M. Stallman <rms@gnu.org>
parents:
56321
diff
changeset
|
2746 this principle is valid. |
6555 | 2747 @end defun |
2748 | |
2749 @defun unhandled-file-name-directory filename | |
21007
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
2750 This function returns the name of a directory that is not magic. It |
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
2751 uses the directory part of @var{filename} if that is not magic. For a |
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
2752 magic file name, it invokes the file name handler, which therefore |
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
2753 decides what value to return. |
6555 | 2754 |
2755 This is useful for running a subprocess; every subprocess must have a | |
2756 non-magic directory to serve as its current directory, and this function | |
2757 is a good way to come up with one. | |
2758 @end defun | |
7088
5a93e6fb43a4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
6555
diff
changeset
|
2759 |
12067 | 2760 @node Format Conversion |
2761 @section File Format Conversion | |
2762 | |
2763 @cindex file format conversion | |
2764 @cindex encoding file formats | |
2765 @cindex decoding file formats | |
2766 The variable @code{format-alist} defines a list of @dfn{file formats}, | |
12098 | 2767 which describe textual representations used in files for the data (text, |
12067 | 2768 text-properties, and possibly other information) in an Emacs buffer. |
12098 | 2769 Emacs performs format conversion if appropriate when reading and writing |
2770 files. | |
12067 | 2771 |
2772 @defvar format-alist | |
2773 This list contains one format definition for each defined file format. | |
2774 @end defvar | |
2775 | |
2776 @cindex format definition | |
2777 Each format definition is a list of this form: | |
2778 | |
2779 @example | |
2780 (@var{name} @var{doc-string} @var{regexp} @var{from-fn} @var{to-fn} @var{modify} @var{mode-fn}) | |
2781 @end example | |
2782 | |
2783 Here is what the elements in a format definition mean: | |
2784 | |
2785 @table @var | |
2786 @item name | |
2787 The name of this format. | |
2788 | |
2789 @item doc-string | |
2790 A documentation string for the format. | |
2791 | |
2792 @item regexp | |
2793 A regular expression which is used to recognize files represented in | |
2794 this format. | |
2795 | |
2796 @item from-fn | |
21682
90da2489c498
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21007
diff
changeset
|
2797 A shell command or function to decode data in this format (to convert |
21007
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
2798 file data into the usual Emacs data representation). |
12067 | 2799 |
21682
90da2489c498
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21007
diff
changeset
|
2800 A shell command is represented as a string; Emacs runs the command as a |
90da2489c498
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21007
diff
changeset
|
2801 filter to perform the conversion. |
90da2489c498
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21007
diff
changeset
|
2802 |
90da2489c498
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21007
diff
changeset
|
2803 If @var{from-fn} is a function, it is called with two arguments, @var{begin} |
21007
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
2804 and @var{end}, which specify the part of the buffer it should convert. |
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
2805 It should convert the text by editing it in place. Since this can |
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
2806 change the length of the text, @var{from-fn} should return the modified |
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
2807 end position. |
12067 | 2808 |
12098 | 2809 One responsibility of @var{from-fn} is to make sure that the beginning |
12067 | 2810 of the file no longer matches @var{regexp}. Otherwise it is likely to |
2811 get called again. | |
2812 | |
2813 @item to-fn | |
21682
90da2489c498
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21007
diff
changeset
|
2814 A shell command or function to encode data in this format---that is, to |
90da2489c498
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21007
diff
changeset
|
2815 convert the usual Emacs data representation into this format. |
12067 | 2816 |
21007
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
2817 If @var{to-fn} is a string, it is a shell command; Emacs runs the |
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
2818 command as a filter to perform the conversion. |
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
2819 |
21682
90da2489c498
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21007
diff
changeset
|
2820 If @var{to-fn} is a function, it is called with two arguments, @var{begin} |
21007
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
2821 and @var{end}, which specify the part of the buffer it should convert. |
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
2822 There are two ways it can do the conversion: |
12067 | 2823 |
2824 @itemize @bullet | |
2825 @item | |
2826 By editing the buffer in place. In this case, @var{to-fn} should | |
2827 return the end-position of the range of text, as modified. | |
2828 | |
2829 @item | |
2830 By returning a list of annotations. This is a list of elements of the | |
2831 form @code{(@var{position} . @var{string})}, where @var{position} is an | |
2832 integer specifying the relative position in the text to be written, and | |
2833 @var{string} is the annotation to add there. The list must be sorted in | |
2834 order of position when @var{to-fn} returns it. | |
2835 | |
2836 When @code{write-region} actually writes the text from the buffer to the | |
2837 file, it intermixes the specified annotations at the corresponding | |
2838 positions. All this takes place without modifying the buffer. | |
2839 @end itemize | |
2840 | |
2841 @item modify | |
2842 A flag, @code{t} if the encoding function modifies the buffer, and | |
2843 @code{nil} if it works by returning a list of annotations. | |
2844 | |
27259
c41efa6c4be1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
27193
diff
changeset
|
2845 @item mode-fn |
c41efa6c4be1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
27193
diff
changeset
|
2846 A minor-mode function to call after visiting a file converted from this |
c41efa6c4be1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
27193
diff
changeset
|
2847 format. The function is called with one argument, the integer 1; |
c41efa6c4be1
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
27193
diff
changeset
|
2848 that tells a minor-mode function to enable the mode. |
12067 | 2849 @end table |
2850 | |
2851 The function @code{insert-file-contents} automatically recognizes file | |
2852 formats when it reads the specified file. It checks the text of the | |
2853 beginning of the file against the regular expressions of the format | |
2854 definitions, and if it finds a match, it calls the decoding function for | |
2855 that format. Then it checks all the known formats over again. | |
2856 It keeps checking them until none of them is applicable. | |
2857 | |
2858 Visiting a file, with @code{find-file-noselect} or the commands that use | |
2859 it, performs conversion likewise (because it calls | |
12098 | 2860 @code{insert-file-contents}); it also calls the mode function for each |
2861 format that it decodes. It stores a list of the format names in the | |
2862 buffer-local variable @code{buffer-file-format}. | |
12067 | 2863 |
2864 @defvar buffer-file-format | |
12098 | 2865 This variable states the format of the visited file. More precisely, |
2866 this is a list of the file format names that were decoded in the course | |
21682
90da2489c498
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21007
diff
changeset
|
2867 of visiting the current buffer's file. It is always buffer-local in all |
12067 | 2868 buffers. |
2869 @end defvar | |
2870 | |
2871 When @code{write-region} writes data into a file, it first calls the | |
12098 | 2872 encoding functions for the formats listed in @code{buffer-file-format}, |
2873 in the order of appearance in the list. | |
12067 | 2874 |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2875 @deffn Command format-write-file file format &optional confirm |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2876 This command writes the current buffer contents into the file |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2877 @var{file} in format @var{format}, and makes that format the default |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2878 for future saves of the buffer. The argument @var{format} is a list |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2879 of format names. Except for the @var{format} argument, this command |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2880 is similar to @code{write-file}. In particular, @var{confirm} has the |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2881 same meaning and interactive treatment as the corresponding argument |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2882 to @code{write-file}. @xref{Definition of write-file}. |
21007
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
2883 @end deffn |
12067 | 2884 |
21007
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
2885 @deffn Command format-find-file file format |
12226 | 2886 This command finds the file @var{file}, converting it according to |
2887 format @var{format}. It also makes @var{format} the default if the | |
2888 buffer is saved later. | |
2889 | |
2890 The argument @var{format} is a list of format names. If @var{format} is | |
2891 @code{nil}, no conversion takes place. Interactively, typing just | |
2892 @key{RET} for @var{format} specifies @code{nil}. | |
21007
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
2893 @end deffn |
12226 | 2894 |
21682
90da2489c498
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21007
diff
changeset
|
2895 @deffn Command format-insert-file file format &optional beg end |
12226 | 2896 This command inserts the contents of file @var{file}, converting it |
2897 according to format @var{format}. If @var{beg} and @var{end} are | |
2898 non-@code{nil}, they specify which part of the file to read, as in | |
2899 @code{insert-file-contents} (@pxref{Reading from Files}). | |
2900 | |
2901 The return value is like what @code{insert-file-contents} returns: a | |
2902 list of the absolute file name and the length of the data inserted | |
2903 (after conversion). | |
2904 | |
2905 The argument @var{format} is a list of format names. If @var{format} is | |
2906 @code{nil}, no conversion takes place. Interactively, typing just | |
2907 @key{RET} for @var{format} specifies @code{nil}. | |
21007
66d807bdc5b4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
17919
diff
changeset
|
2908 @end deffn |
12226 | 2909 |
56981
54f19dd158e9
(Format Conversion): `auto-save-file-format' has been renamed
Luc Teirlinck <teirllm@auburn.edu>
parents:
56322
diff
changeset
|
2910 @defvar buffer-auto-save-file-format |
12067 | 2911 This variable specifies the format to use for auto-saving. Its value is |
2912 a list of format names, just like the value of | |
22138
d4ac295a98b3
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
21682
diff
changeset
|
2913 @code{buffer-file-format}; however, it is used instead of |
54861
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2914 @code{buffer-file-format} for writing auto-save files. If the value |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2915 is @code{t}, the default, auto-saving uses the same format as a |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2916 regular save in the same buffer. This variable is always buffer-local |
5af1398ad8e2
Various changes in addition to:
Luc Teirlinck <teirllm@auburn.edu>
parents:
54025
diff
changeset
|
2917 in all buffers. |
7088
5a93e6fb43a4
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
6555
diff
changeset
|
2918 @end defvar |
52401 | 2919 |
2920 @ignore | |
2921 arch-tag: 141f74ce-6ae3-40dc-a6c4-ef83fc4ec35c | |
2922 @end ignore |