Mercurial > emacs
annotate src/dired.c @ 23323:0800a4f84757
(underlying_strftime):
Set the buffer to a nonzero value before calling
strftime, and check to see whether strftime has set the buffer to zero.
This lets us distinguish between an empty buffer and an error.
I'm installing this patch by hand now; it will be superseded whenever
the glibc sources are propagated back to fsf.org.
| author | Paul Eggert <eggert@twinsun.com> |
|---|---|
| date | Fri, 25 Sep 1998 21:40:23 +0000 |
| parents | 596fa4fbae13 |
| children | d968067e4580 |
| rev | line source |
|---|---|
| 153 | 1 /* Lisp functions for making directory listings. |
| 7307 | 2 Copyright (C) 1985, 1986, 1993, 1994 Free Software Foundation, Inc. |
| 153 | 3 |
| 4 This file is part of GNU Emacs. | |
| 5 | |
| 6 GNU Emacs is free software; you can redistribute it and/or modify | |
| 7 it under the terms of the GNU General Public License as published by | |
| 12244 | 8 the Free Software Foundation; either version 2, or (at your option) |
| 153 | 9 any later version. |
| 10 | |
| 11 GNU Emacs is distributed in the hope that it will be useful, | |
| 12 but WITHOUT ANY WARRANTY; without even the implied warranty of | |
| 13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
| 14 GNU General Public License for more details. | |
| 15 | |
| 16 You should have received a copy of the GNU General Public License | |
| 17 along with GNU Emacs; see the file COPYING. If not, write to | |
|
14186
ee40177f6c68
Update FSF's address in the preamble.
Erik Naggum <erik@naggum.no>
parents:
14067
diff
changeset
|
18 the Free Software Foundation, Inc., 59 Temple Place - Suite 330, |
|
ee40177f6c68
Update FSF's address in the preamble.
Erik Naggum <erik@naggum.no>
parents:
14067
diff
changeset
|
19 Boston, MA 02111-1307, USA. */ |
| 153 | 20 |
| 21 | |
|
7896
ec45b17e09b3
Put stdio.h, sys/types.h and sys/stat.h after config.h.
Richard M. Stallman <rms@gnu.org>
parents:
7307
diff
changeset
|
22 #include <config.h> |
|
ec45b17e09b3
Put stdio.h, sys/types.h and sys/stat.h after config.h.
Richard M. Stallman <rms@gnu.org>
parents:
7307
diff
changeset
|
23 |
| 153 | 24 #include <stdio.h> |
| 25 #include <sys/types.h> | |
| 26 #include <sys/stat.h> | |
| 27 | |
|
1172
c942305917c1
[VMS]: Include string.h, rms.h, rmsdef.h.
Richard M. Stallman <rms@gnu.org>
parents:
847
diff
changeset
|
28 #ifdef VMS |
|
c942305917c1
[VMS]: Include string.h, rms.h, rmsdef.h.
Richard M. Stallman <rms@gnu.org>
parents:
847
diff
changeset
|
29 #include <string.h> |
|
c942305917c1
[VMS]: Include string.h, rms.h, rmsdef.h.
Richard M. Stallman <rms@gnu.org>
parents:
847
diff
changeset
|
30 #include <rms.h> |
|
c942305917c1
[VMS]: Include string.h, rms.h, rmsdef.h.
Richard M. Stallman <rms@gnu.org>
parents:
847
diff
changeset
|
31 #include <rmsdef.h> |
|
c942305917c1
[VMS]: Include string.h, rms.h, rmsdef.h.
Richard M. Stallman <rms@gnu.org>
parents:
847
diff
changeset
|
32 #endif |
|
c942305917c1
[VMS]: Include string.h, rms.h, rmsdef.h.
Richard M. Stallman <rms@gnu.org>
parents:
847
diff
changeset
|
33 |
| 21514 | 34 #ifdef HAVE_UNISTD_H |
| 35 #include <unistd.h> | |
| 36 #endif | |
| 37 | |
|
2117
cb164a9e44ba
* dired.c (NAMLEN): Never use d_nameln to get the length of the
Jim Blandy <jimb@redhat.com>
parents:
1681
diff
changeset
|
38 /* The d_nameln member of a struct dirent includes the '\0' character |
|
cb164a9e44ba
* dired.c (NAMLEN): Never use d_nameln to get the length of the
Jim Blandy <jimb@redhat.com>
parents:
1681
diff
changeset
|
39 on some systems, but not on others. What's worse, you can't tell |
|
cb164a9e44ba
* dired.c (NAMLEN): Never use d_nameln to get the length of the
Jim Blandy <jimb@redhat.com>
parents:
1681
diff
changeset
|
40 at compile-time which one it will be, since it really depends on |
|
cb164a9e44ba
* dired.c (NAMLEN): Never use d_nameln to get the length of the
Jim Blandy <jimb@redhat.com>
parents:
1681
diff
changeset
|
41 the sort of system providing the filesystem you're reading from, |
|
cb164a9e44ba
* dired.c (NAMLEN): Never use d_nameln to get the length of the
Jim Blandy <jimb@redhat.com>
parents:
1681
diff
changeset
|
42 not the system you are running on. Paul Eggert |
|
cb164a9e44ba
* dired.c (NAMLEN): Never use d_nameln to get the length of the
Jim Blandy <jimb@redhat.com>
parents:
1681
diff
changeset
|
43 <eggert@bi.twinsun.com> says this occurs when Emacs is running on a |
|
cb164a9e44ba
* dired.c (NAMLEN): Never use d_nameln to get the length of the
Jim Blandy <jimb@redhat.com>
parents:
1681
diff
changeset
|
44 SunOS 4.1.2 host, reading a directory that is remote-mounted from a |
|
cb164a9e44ba
* dired.c (NAMLEN): Never use d_nameln to get the length of the
Jim Blandy <jimb@redhat.com>
parents:
1681
diff
changeset
|
45 Solaris 2.1 host and is in a native Solaris 2.1 filesystem. |
|
cb164a9e44ba
* dired.c (NAMLEN): Never use d_nameln to get the length of the
Jim Blandy <jimb@redhat.com>
parents:
1681
diff
changeset
|
46 |
|
cb164a9e44ba
* dired.c (NAMLEN): Never use d_nameln to get the length of the
Jim Blandy <jimb@redhat.com>
parents:
1681
diff
changeset
|
47 Since applying strlen to the name always works, we'll just do that. */ |
|
cb164a9e44ba
* dired.c (NAMLEN): Never use d_nameln to get the length of the
Jim Blandy <jimb@redhat.com>
parents:
1681
diff
changeset
|
48 #define NAMLEN(p) strlen (p->d_name) |
|
cb164a9e44ba
* dired.c (NAMLEN): Never use d_nameln to get the length of the
Jim Blandy <jimb@redhat.com>
parents:
1681
diff
changeset
|
49 |
| 153 | 50 #ifdef SYSV_SYSTEM_DIR |
| 51 | |
| 52 #include <dirent.h> | |
| 53 #define DIRENTRY struct dirent | |
| 54 | |
|
5492
ededb7b52564
(DIRENTRY_NONEMPTY): New macro; two definitions.
Richard M. Stallman <rms@gnu.org>
parents:
5432
diff
changeset
|
55 #else /* not SYSV_SYSTEM_DIR */ |
| 153 | 56 |
| 57 #ifdef NONSYSTEM_DIR_LIBRARY | |
| 58 #include "ndir.h" | |
| 59 #else /* not NONSYSTEM_DIR_LIBRARY */ | |
|
5492
ededb7b52564
(DIRENTRY_NONEMPTY): New macro; two definitions.
Richard M. Stallman <rms@gnu.org>
parents:
5432
diff
changeset
|
60 #ifdef MSDOS |
|
ededb7b52564
(DIRENTRY_NONEMPTY): New macro; two definitions.
Richard M. Stallman <rms@gnu.org>
parents:
5432
diff
changeset
|
61 #include <dirent.h> |
|
ededb7b52564
(DIRENTRY_NONEMPTY): New macro; two definitions.
Richard M. Stallman <rms@gnu.org>
parents:
5432
diff
changeset
|
62 #else |
| 153 | 63 #include <sys/dir.h> |
|
5492
ededb7b52564
(DIRENTRY_NONEMPTY): New macro; two definitions.
Richard M. Stallman <rms@gnu.org>
parents:
5432
diff
changeset
|
64 #endif |
| 153 | 65 #endif /* not NONSYSTEM_DIR_LIBRARY */ |
| 66 | |
|
5492
ededb7b52564
(DIRENTRY_NONEMPTY): New macro; two definitions.
Richard M. Stallman <rms@gnu.org>
parents:
5432
diff
changeset
|
67 #ifndef MSDOS |
| 153 | 68 #define DIRENTRY struct direct |
| 69 | |
| 70 extern DIR *opendir (); | |
| 71 extern struct direct *readdir (); | |
| 72 | |
|
5492
ededb7b52564
(DIRENTRY_NONEMPTY): New macro; two definitions.
Richard M. Stallman <rms@gnu.org>
parents:
5432
diff
changeset
|
73 #endif /* not MSDOS */ |
|
ededb7b52564
(DIRENTRY_NONEMPTY): New macro; two definitions.
Richard M. Stallman <rms@gnu.org>
parents:
5432
diff
changeset
|
74 #endif /* not SYSV_SYSTEM_DIR */ |
|
ededb7b52564
(DIRENTRY_NONEMPTY): New macro; two definitions.
Richard M. Stallman <rms@gnu.org>
parents:
5432
diff
changeset
|
75 |
|
ededb7b52564
(DIRENTRY_NONEMPTY): New macro; two definitions.
Richard M. Stallman <rms@gnu.org>
parents:
5432
diff
changeset
|
76 #ifdef MSDOS |
|
ededb7b52564
(DIRENTRY_NONEMPTY): New macro; two definitions.
Richard M. Stallman <rms@gnu.org>
parents:
5432
diff
changeset
|
77 #define DIRENTRY_NONEMPTY(p) ((p)->d_name[0] != 0) |
|
ededb7b52564
(DIRENTRY_NONEMPTY): New macro; two definitions.
Richard M. Stallman <rms@gnu.org>
parents:
5432
diff
changeset
|
78 #else |
|
ededb7b52564
(DIRENTRY_NONEMPTY): New macro; two definitions.
Richard M. Stallman <rms@gnu.org>
parents:
5432
diff
changeset
|
79 #define DIRENTRY_NONEMPTY(p) ((p)->d_ino) |
| 153 | 80 #endif |
| 81 | |
| 82 #include "lisp.h" | |
| 83 #include "buffer.h" | |
| 84 #include "commands.h" | |
|
21050
13e905e1d33c
Include charset.h and coding.h.
Kenichi Handa <handa@m17n.org>
parents:
20870
diff
changeset
|
85 #include "charset.h" |
|
13e905e1d33c
Include charset.h and coding.h.
Kenichi Handa <handa@m17n.org>
parents:
20870
diff
changeset
|
86 #include "coding.h" |
| 153 | 87 #include "regex.h" |
| 88 | |
|
9604
d3f06c8c76a1
(Fdirectory_files): Use the new calling convention for compile_pattern.
Karl Heuer <kwzh@gnu.org>
parents:
9399
diff
changeset
|
89 /* Returns a search buffer, with a fastmap allocated and ready to go. */ |
|
d3f06c8c76a1
(Fdirectory_files): Use the new calling convention for compile_pattern.
Karl Heuer <kwzh@gnu.org>
parents:
9399
diff
changeset
|
90 extern struct re_pattern_buffer *compile_pattern (); |
|
2371
48f808108031
(searchbuf): Declare here.
Richard M. Stallman <rms@gnu.org>
parents:
2183
diff
changeset
|
91 |
| 153 | 92 #define min(a, b) ((a) < (b) ? (a) : (b)) |
| 93 | |
| 94 /* if system does not have symbolic links, it does not have lstat. | |
| 95 In that case, use ordinary stat instead. */ | |
| 96 | |
| 97 #ifndef S_IFLNK | |
| 98 #define lstat stat | |
| 99 #endif | |
| 100 | |
|
4778
76f267188bbd
(file_name_completion): Install case-preserving changes from Emacs 18
Brian Fox <bfox@gnu.org>
parents:
4696
diff
changeset
|
101 extern int completion_ignore_case; |
|
6680
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
102 extern Lisp_Object Vcompletion_regexp_list; |
|
21050
13e905e1d33c
Include charset.h and coding.h.
Kenichi Handa <handa@m17n.org>
parents:
20870
diff
changeset
|
103 extern Lisp_Object Vfile_name_coding_system, Vdefault_file_name_coding_system; |
|
1509
9675ae1d95c2
* dired.c (find_file_handler): Declare this extern.
Jim Blandy <jimb@redhat.com>
parents:
1173
diff
changeset
|
104 |
| 153 | 105 Lisp_Object Vcompletion_ignored_extensions; |
| 106 Lisp_Object Qcompletion_ignore_case; | |
|
843
8f6ea998ad0a
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
107 Lisp_Object Qdirectory_files; |
|
8f6ea998ad0a
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
108 Lisp_Object Qfile_name_completion; |
|
8f6ea998ad0a
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
109 Lisp_Object Qfile_name_all_completions; |
| 847 | 110 Lisp_Object Qfile_attributes; |
| 153 | 111 |
| 112 DEFUN ("directory-files", Fdirectory_files, Sdirectory_files, 1, 4, 0, | |
| 113 "Return a list of names of files in DIRECTORY.\n\ | |
| 114 There are three optional arguments:\n\ | |
|
14524
10110e5a680a
(Fdirectory_files): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
14186
diff
changeset
|
115 If FULL is non-nil, return absolute file names. Otherwise return names\n\ |
|
10110e5a680a
(Fdirectory_files): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
14186
diff
changeset
|
116 that are relative to the specified directory.\n\ |
|
10110e5a680a
(Fdirectory_files): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
14186
diff
changeset
|
117 If MATCH is non-nil, mention only file names that match the regexp MATCH.\n\ |
| 153 | 118 If NOSORT is non-nil, the list is not sorted--its order is unpredictable.\n\ |
| 119 NOSORT is useful if you plan to sort the result yourself.") | |
|
14067
afef050ad4e6
(Fdirectory_files, Ffile_name_completion, Ffile_name_all_completions,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
120 (directory, full, match, nosort) |
|
afef050ad4e6
(Fdirectory_files, Ffile_name_completion, Ffile_name_all_completions,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
121 Lisp_Object directory, full, match, nosort; |
| 153 | 122 { |
| 123 DIR *d; | |
|
11176
07a3b9c34717
(Fdirectory_files): Fix bug in IS_ANY_SEP usage introduced in Oct 30 change.
Richard M. Stallman <rms@gnu.org>
parents:
9984
diff
changeset
|
124 int dirnamelen; |
|
2182
4ffe88f2e493
* dired.c (Fdirectory_files): Compile the MATCH regexp after
Jim Blandy <jimb@redhat.com>
parents:
2117
diff
changeset
|
125 Lisp_Object list, name, dirfilename; |
|
19816
902043a3c18a
(ENCODE_FILE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
18666
diff
changeset
|
126 Lisp_Object encoded_directory; |
|
843
8f6ea998ad0a
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
127 Lisp_Object handler; |
|
9604
d3f06c8c76a1
(Fdirectory_files): Use the new calling convention for compile_pattern.
Karl Heuer <kwzh@gnu.org>
parents:
9399
diff
changeset
|
128 struct re_pattern_buffer *bufp; |
|
21380
28b9e0d48deb
(Fdirectory_files): GCPRO encoded_directory and list.
Andreas Schwab <schwab@suse.de>
parents:
21261
diff
changeset
|
129 int needsep = 0; |
|
28b9e0d48deb
(Fdirectory_files): GCPRO encoded_directory and list.
Andreas Schwab <schwab@suse.de>
parents:
21261
diff
changeset
|
130 struct gcpro gcpro1, gcpro2; |
|
843
8f6ea998ad0a
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
131 |
|
8f6ea998ad0a
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
132 /* If the file name has special constructs in it, |
|
8f6ea998ad0a
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
133 call the corresponding file handler. */ |
|
14067
afef050ad4e6
(Fdirectory_files, Ffile_name_completion, Ffile_name_all_completions,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
134 handler = Ffind_file_name_handler (directory, Qdirectory_files); |
|
843
8f6ea998ad0a
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
135 if (!NILP (handler)) |
|
8f6ea998ad0a
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
136 { |
|
8f6ea998ad0a
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
137 Lisp_Object args[6]; |
|
8f6ea998ad0a
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
138 |
|
8f6ea998ad0a
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
139 args[0] = handler; |
|
8f6ea998ad0a
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
140 args[1] = Qdirectory_files; |
|
14067
afef050ad4e6
(Fdirectory_files, Ffile_name_completion, Ffile_name_all_completions,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
141 args[2] = directory; |
|
843
8f6ea998ad0a
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
142 args[3] = full; |
|
8f6ea998ad0a
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
143 args[4] = match; |
|
8f6ea998ad0a
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
144 args[5] = nosort; |
|
8f6ea998ad0a
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
145 return Ffuncall (6, args); |
|
8f6ea998ad0a
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
146 } |
| 153 | 147 |
|
21380
28b9e0d48deb
(Fdirectory_files): GCPRO encoded_directory and list.
Andreas Schwab <schwab@suse.de>
parents:
21261
diff
changeset
|
148 /* Because of file name handlers, these functions might call |
|
2182
4ffe88f2e493
* dired.c (Fdirectory_files): Compile the MATCH regexp after
Jim Blandy <jimb@redhat.com>
parents:
2117
diff
changeset
|
149 Ffuncall, and cause a GC. */ |
|
21380
28b9e0d48deb
(Fdirectory_files): GCPRO encoded_directory and list.
Andreas Schwab <schwab@suse.de>
parents:
21261
diff
changeset
|
150 GCPRO1 (match); |
|
28b9e0d48deb
(Fdirectory_files): GCPRO encoded_directory and list.
Andreas Schwab <schwab@suse.de>
parents:
21261
diff
changeset
|
151 directory = Fexpand_file_name (directory, Qnil); |
|
28b9e0d48deb
(Fdirectory_files): GCPRO encoded_directory and list.
Andreas Schwab <schwab@suse.de>
parents:
21261
diff
changeset
|
152 UNGCPRO; |
|
28b9e0d48deb
(Fdirectory_files): GCPRO encoded_directory and list.
Andreas Schwab <schwab@suse.de>
parents:
21261
diff
changeset
|
153 GCPRO2 (match, directory); |
|
28b9e0d48deb
(Fdirectory_files): GCPRO encoded_directory and list.
Andreas Schwab <schwab@suse.de>
parents:
21261
diff
changeset
|
154 dirfilename = Fdirectory_file_name (directory); |
|
28b9e0d48deb
(Fdirectory_files): GCPRO encoded_directory and list.
Andreas Schwab <schwab@suse.de>
parents:
21261
diff
changeset
|
155 UNGCPRO; |
|
2182
4ffe88f2e493
* dired.c (Fdirectory_files): Compile the MATCH regexp after
Jim Blandy <jimb@redhat.com>
parents:
2117
diff
changeset
|
156 |
| 485 | 157 if (!NILP (match)) |
| 153 | 158 { |
| 159 CHECK_STRING (match, 3); | |
| 808 | 160 |
| 161 /* MATCH might be a flawed regular expression. Rather than | |
| 14036 | 162 catching and signaling our own errors, we just call |
| 808 | 163 compile_pattern to do the work for us. */ |
|
20634
8e7e791c49ca
(Fdirectory_files): Fix arg to compile_pattern.
Richard M. Stallman <rms@gnu.org>
parents:
19816
diff
changeset
|
164 /* Pass 1 for the MULTIBYTE arg |
|
8e7e791c49ca
(Fdirectory_files): Fix arg to compile_pattern.
Richard M. Stallman <rms@gnu.org>
parents:
19816
diff
changeset
|
165 because we do make multibyte strings if the contents warrant. */ |
| 153 | 166 #ifdef VMS |
|
9604
d3f06c8c76a1
(Fdirectory_files): Use the new calling convention for compile_pattern.
Karl Heuer <kwzh@gnu.org>
parents:
9399
diff
changeset
|
167 bufp = compile_pattern (match, 0, |
|
20870
3b8d9a7be50c
(Fdirectory_files): Call compile_pattern the new way.
Richard M. Stallman <rms@gnu.org>
parents:
20634
diff
changeset
|
168 buffer_defaults.downcase_table, 0, 1); |
| 153 | 169 #else |
|
20870
3b8d9a7be50c
(Fdirectory_files): Call compile_pattern the new way.
Richard M. Stallman <rms@gnu.org>
parents:
20634
diff
changeset
|
170 bufp = compile_pattern (match, 0, Qnil, 0, 1); |
| 153 | 171 #endif |
| 172 } | |
| 173 | |
|
19816
902043a3c18a
(ENCODE_FILE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
18666
diff
changeset
|
174 dirfilename = ENCODE_FILE (dirfilename); |
|
902043a3c18a
(ENCODE_FILE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
18666
diff
changeset
|
175 |
|
902043a3c18a
(ENCODE_FILE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
18666
diff
changeset
|
176 encoded_directory = ENCODE_FILE (directory); |
|
902043a3c18a
(ENCODE_FILE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
18666
diff
changeset
|
177 |
|
9604
d3f06c8c76a1
(Fdirectory_files): Use the new calling convention for compile_pattern.
Karl Heuer <kwzh@gnu.org>
parents:
9399
diff
changeset
|
178 /* Now *bufp is the compiled form of MATCH; don't call anything |
|
2182
4ffe88f2e493
* dired.c (Fdirectory_files): Compile the MATCH regexp after
Jim Blandy <jimb@redhat.com>
parents:
2117
diff
changeset
|
179 which might compile a new regexp until we're done with the loop! */ |
|
4ffe88f2e493
* dired.c (Fdirectory_files): Compile the MATCH regexp after
Jim Blandy <jimb@redhat.com>
parents:
2117
diff
changeset
|
180 |
|
4ffe88f2e493
* dired.c (Fdirectory_files): Compile the MATCH regexp after
Jim Blandy <jimb@redhat.com>
parents:
2117
diff
changeset
|
181 /* Do this opendir after anything which might signal an error; if |
| 14036 | 182 an error is signaled while the directory stream is open, we |
|
2182
4ffe88f2e493
* dired.c (Fdirectory_files): Compile the MATCH regexp after
Jim Blandy <jimb@redhat.com>
parents:
2117
diff
changeset
|
183 have to make sure it gets closed, and setting up an |
|
4ffe88f2e493
* dired.c (Fdirectory_files): Compile the MATCH regexp after
Jim Blandy <jimb@redhat.com>
parents:
2117
diff
changeset
|
184 unwind_protect to do so would be a pain. */ |
|
4ffe88f2e493
* dired.c (Fdirectory_files): Compile the MATCH regexp after
Jim Blandy <jimb@redhat.com>
parents:
2117
diff
changeset
|
185 d = opendir (XSTRING (dirfilename)->data); |
|
4ffe88f2e493
* dired.c (Fdirectory_files): Compile the MATCH regexp after
Jim Blandy <jimb@redhat.com>
parents:
2117
diff
changeset
|
186 if (! d) |
|
14067
afef050ad4e6
(Fdirectory_files, Ffile_name_completion, Ffile_name_all_completions,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
187 report_file_error ("Opening directory", Fcons (directory, Qnil)); |
| 153 | 188 |
| 189 list = Qnil; | |
|
22916
596fa4fbae13
(Fdirectory_files): If MATCH is non-nil, decode filenames
Kenichi Handa <handa@m17n.org>
parents:
21514
diff
changeset
|
190 dirnamelen = STRING_BYTES (XSTRING (directory)); |
|
17460
6923ae3375f7
(Fdirectory_files): Set re_match_object.
Richard M. Stallman <rms@gnu.org>
parents:
16532
diff
changeset
|
191 re_match_object = Qt; |
| 153 | 192 |
|
21380
28b9e0d48deb
(Fdirectory_files): GCPRO encoded_directory and list.
Andreas Schwab <schwab@suse.de>
parents:
21261
diff
changeset
|
193 /* Decide whether we need to add a directory separator. */ |
|
28b9e0d48deb
(Fdirectory_files): GCPRO encoded_directory and list.
Andreas Schwab <schwab@suse.de>
parents:
21261
diff
changeset
|
194 #ifndef VMS |
|
28b9e0d48deb
(Fdirectory_files): GCPRO encoded_directory and list.
Andreas Schwab <schwab@suse.de>
parents:
21261
diff
changeset
|
195 if (dirnamelen == 0 |
|
22916
596fa4fbae13
(Fdirectory_files): If MATCH is non-nil, decode filenames
Kenichi Handa <handa@m17n.org>
parents:
21514
diff
changeset
|
196 || !IS_ANY_SEP (XSTRING (directory)->data[dirnamelen - 1])) |
|
21380
28b9e0d48deb
(Fdirectory_files): GCPRO encoded_directory and list.
Andreas Schwab <schwab@suse.de>
parents:
21261
diff
changeset
|
197 needsep = 1; |
|
21393
5f153464fc99
(Fdirectory_files): Use make_uninit_multibyte_string.
Karl Heuer <kwzh@gnu.org>
parents:
21380
diff
changeset
|
198 #endif /* not VMS */ |
|
21380
28b9e0d48deb
(Fdirectory_files): GCPRO encoded_directory and list.
Andreas Schwab <schwab@suse.de>
parents:
21261
diff
changeset
|
199 |
|
28b9e0d48deb
(Fdirectory_files): GCPRO encoded_directory and list.
Andreas Schwab <schwab@suse.de>
parents:
21261
diff
changeset
|
200 GCPRO2 (encoded_directory, list); |
|
28b9e0d48deb
(Fdirectory_files): GCPRO encoded_directory and list.
Andreas Schwab <schwab@suse.de>
parents:
21261
diff
changeset
|
201 |
| 153 | 202 /* Loop reading blocks */ |
| 203 while (1) | |
| 204 { | |
| 205 DIRENTRY *dp = readdir (d); | |
| 206 | |
| 207 if (!dp) break; | |
|
5492
ededb7b52564
(DIRENTRY_NONEMPTY): New macro; two definitions.
Richard M. Stallman <rms@gnu.org>
parents:
5432
diff
changeset
|
208 if (DIRENTRY_NONEMPTY (dp)) |
| 153 | 209 { |
|
22916
596fa4fbae13
(Fdirectory_files): If MATCH is non-nil, decode filenames
Kenichi Handa <handa@m17n.org>
parents:
21514
diff
changeset
|
210 int len; |
|
596fa4fbae13
(Fdirectory_files): If MATCH is non-nil, decode filenames
Kenichi Handa <handa@m17n.org>
parents:
21514
diff
changeset
|
211 |
|
596fa4fbae13
(Fdirectory_files): If MATCH is non-nil, decode filenames
Kenichi Handa <handa@m17n.org>
parents:
21514
diff
changeset
|
212 len = NAMLEN (dp); |
|
596fa4fbae13
(Fdirectory_files): If MATCH is non-nil, decode filenames
Kenichi Handa <handa@m17n.org>
parents:
21514
diff
changeset
|
213 name = DECODE_FILE (make_string (dp->d_name, len)); |
|
596fa4fbae13
(Fdirectory_files): If MATCH is non-nil, decode filenames
Kenichi Handa <handa@m17n.org>
parents:
21514
diff
changeset
|
214 len = STRING_BYTES (XSTRING (name)); |
|
596fa4fbae13
(Fdirectory_files): If MATCH is non-nil, decode filenames
Kenichi Handa <handa@m17n.org>
parents:
21514
diff
changeset
|
215 |
| 485 | 216 if (NILP (match) |
|
22916
596fa4fbae13
(Fdirectory_files): If MATCH is non-nil, decode filenames
Kenichi Handa <handa@m17n.org>
parents:
21514
diff
changeset
|
217 || (0 <= re_search (bufp, XSTRING (name)->data, len, 0, len, 0))) |
| 153 | 218 { |
| 485 | 219 if (!NILP (full)) |
| 153 | 220 { |
|
11176
07a3b9c34717
(Fdirectory_files): Fix bug in IS_ANY_SEP usage introduced in Oct 30 change.
Richard M. Stallman <rms@gnu.org>
parents:
9984
diff
changeset
|
221 int afterdirindex = dirnamelen; |
|
07a3b9c34717
(Fdirectory_files): Fix bug in IS_ANY_SEP usage introduced in Oct 30 change.
Richard M. Stallman <rms@gnu.org>
parents:
9984
diff
changeset
|
222 int total = len + dirnamelen; |
|
21261
edaef0e79ff0
(Fdirectory_files): In FULL case, compute number of characters
Richard M. Stallman <rms@gnu.org>
parents:
21050
diff
changeset
|
223 int nchars; |
|
22916
596fa4fbae13
(Fdirectory_files): If MATCH is non-nil, decode filenames
Kenichi Handa <handa@m17n.org>
parents:
21514
diff
changeset
|
224 Lisp_Object fullname; |
|
11176
07a3b9c34717
(Fdirectory_files): Fix bug in IS_ANY_SEP usage introduced in Oct 30 change.
Richard M. Stallman <rms@gnu.org>
parents:
9984
diff
changeset
|
225 |
|
22916
596fa4fbae13
(Fdirectory_files): If MATCH is non-nil, decode filenames
Kenichi Handa <handa@m17n.org>
parents:
21514
diff
changeset
|
226 fullname = make_uninit_multibyte_string (total + needsep, |
|
596fa4fbae13
(Fdirectory_files): If MATCH is non-nil, decode filenames
Kenichi Handa <handa@m17n.org>
parents:
21514
diff
changeset
|
227 total + needsep); |
|
596fa4fbae13
(Fdirectory_files): If MATCH is non-nil, decode filenames
Kenichi Handa <handa@m17n.org>
parents:
21514
diff
changeset
|
228 bcopy (XSTRING (directory)->data, XSTRING (fullname)->data, |
|
11176
07a3b9c34717
(Fdirectory_files): Fix bug in IS_ANY_SEP usage introduced in Oct 30 change.
Richard M. Stallman <rms@gnu.org>
parents:
9984
diff
changeset
|
229 dirnamelen); |
|
07a3b9c34717
(Fdirectory_files): Fix bug in IS_ANY_SEP usage introduced in Oct 30 change.
Richard M. Stallman <rms@gnu.org>
parents:
9984
diff
changeset
|
230 if (needsep) |
|
22916
596fa4fbae13
(Fdirectory_files): If MATCH is non-nil, decode filenames
Kenichi Handa <handa@m17n.org>
parents:
21514
diff
changeset
|
231 XSTRING (fullname)->data[afterdirindex++] = DIRECTORY_SEP; |
|
596fa4fbae13
(Fdirectory_files): If MATCH is non-nil, decode filenames
Kenichi Handa <handa@m17n.org>
parents:
21514
diff
changeset
|
232 bcopy (XSTRING (name)->data, |
|
596fa4fbae13
(Fdirectory_files): If MATCH is non-nil, decode filenames
Kenichi Handa <handa@m17n.org>
parents:
21514
diff
changeset
|
233 XSTRING (fullname)->data + afterdirindex, len); |
|
596fa4fbae13
(Fdirectory_files): If MATCH is non-nil, decode filenames
Kenichi Handa <handa@m17n.org>
parents:
21514
diff
changeset
|
234 nchars = chars_in_text (XSTRING (fullname)->data, |
|
21261
edaef0e79ff0
(Fdirectory_files): In FULL case, compute number of characters
Richard M. Stallman <rms@gnu.org>
parents:
21050
diff
changeset
|
235 afterdirindex + len); |
|
22916
596fa4fbae13
(Fdirectory_files): If MATCH is non-nil, decode filenames
Kenichi Handa <handa@m17n.org>
parents:
21514
diff
changeset
|
236 XSTRING (fullname)->size = nchars; |
|
596fa4fbae13
(Fdirectory_files): If MATCH is non-nil, decode filenames
Kenichi Handa <handa@m17n.org>
parents:
21514
diff
changeset
|
237 if (nchars == STRING_BYTES (XSTRING (fullname))) |
|
596fa4fbae13
(Fdirectory_files): If MATCH is non-nil, decode filenames
Kenichi Handa <handa@m17n.org>
parents:
21514
diff
changeset
|
238 SET_STRING_BYTES (XSTRING (fullname), -1); |
|
596fa4fbae13
(Fdirectory_files): If MATCH is non-nil, decode filenames
Kenichi Handa <handa@m17n.org>
parents:
21514
diff
changeset
|
239 name = fullname; |
| 153 | 240 } |
| 241 list = Fcons (name, list); | |
| 242 } | |
| 243 } | |
| 244 } | |
| 245 closedir (d); | |
|
21380
28b9e0d48deb
(Fdirectory_files): GCPRO encoded_directory and list.
Andreas Schwab <schwab@suse.de>
parents:
21261
diff
changeset
|
246 UNGCPRO; |
| 485 | 247 if (!NILP (nosort)) |
| 153 | 248 return list; |
| 249 return Fsort (Fnreverse (list), Qstring_lessp); | |
| 250 } | |
| 251 | |
| 252 Lisp_Object file_name_completion (); | |
| 253 | |
| 254 DEFUN ("file-name-completion", Ffile_name_completion, Sfile_name_completion, | |
| 255 2, 2, 0, | |
|
14067
afef050ad4e6
(Fdirectory_files, Ffile_name_completion, Ffile_name_all_completions,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
256 "Complete file name FILE in directory DIRECTORY.\n\ |
| 153 | 257 Returns the longest string\n\ |
|
14524
10110e5a680a
(Fdirectory_files): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
14186
diff
changeset
|
258 common to all file names in DIRECTORY that start with FILE.\n\ |
| 153 | 259 If there is only one and FILE matches it exactly, returns t.\n\ |
| 260 Returns nil if DIR contains no name starting with FILE.") | |
|
14067
afef050ad4e6
(Fdirectory_files, Ffile_name_completion, Ffile_name_all_completions,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
261 (file, directory) |
|
afef050ad4e6
(Fdirectory_files, Ffile_name_completion, Ffile_name_all_completions,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
262 Lisp_Object file, directory; |
| 153 | 263 { |
|
843
8f6ea998ad0a
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
264 Lisp_Object handler; |
|
8f6ea998ad0a
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
265 |
|
12984
7c38c6da4aae
(Ffile_name_all_completions, Ffile_name_completion):
Richard M. Stallman <rms@gnu.org>
parents:
12244
diff
changeset
|
266 /* If the directory name has special constructs in it, |
|
7c38c6da4aae
(Ffile_name_all_completions, Ffile_name_completion):
Richard M. Stallman <rms@gnu.org>
parents:
12244
diff
changeset
|
267 call the corresponding file handler. */ |
|
14067
afef050ad4e6
(Fdirectory_files, Ffile_name_completion, Ffile_name_all_completions,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
268 handler = Ffind_file_name_handler (directory, Qfile_name_completion); |
|
12984
7c38c6da4aae
(Ffile_name_all_completions, Ffile_name_completion):
Richard M. Stallman <rms@gnu.org>
parents:
12244
diff
changeset
|
269 if (!NILP (handler)) |
|
14067
afef050ad4e6
(Fdirectory_files, Ffile_name_completion, Ffile_name_all_completions,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
270 return call3 (handler, Qfile_name_completion, file, directory); |
|
12984
7c38c6da4aae
(Ffile_name_all_completions, Ffile_name_completion):
Richard M. Stallman <rms@gnu.org>
parents:
12244
diff
changeset
|
271 |
|
843
8f6ea998ad0a
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
272 /* If the file name has special constructs in it, |
|
8f6ea998ad0a
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
273 call the corresponding file handler. */ |
|
12984
7c38c6da4aae
(Ffile_name_all_completions, Ffile_name_completion):
Richard M. Stallman <rms@gnu.org>
parents:
12244
diff
changeset
|
274 handler = Ffind_file_name_handler (file, Qfile_name_completion); |
|
843
8f6ea998ad0a
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
275 if (!NILP (handler)) |
|
14067
afef050ad4e6
(Fdirectory_files, Ffile_name_completion, Ffile_name_all_completions,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
276 return call3 (handler, Qfile_name_completion, file, directory); |
|
843
8f6ea998ad0a
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
277 |
|
14067
afef050ad4e6
(Fdirectory_files, Ffile_name_completion, Ffile_name_all_completions,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
278 return file_name_completion (file, directory, 0, 0); |
| 153 | 279 } |
| 280 | |
| 281 DEFUN ("file-name-all-completions", Ffile_name_all_completions, | |
| 282 Sfile_name_all_completions, 2, 2, 0, | |
|
14067
afef050ad4e6
(Fdirectory_files, Ffile_name_completion, Ffile_name_all_completions,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
283 "Return a list of all completions of file name FILE in directory DIRECTORY.\n\ |
|
afef050ad4e6
(Fdirectory_files, Ffile_name_completion, Ffile_name_all_completions,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
284 These are all file names in directory DIRECTORY which begin with FILE.") |
|
afef050ad4e6
(Fdirectory_files, Ffile_name_completion, Ffile_name_all_completions,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
285 (file, directory) |
|
afef050ad4e6
(Fdirectory_files, Ffile_name_completion, Ffile_name_all_completions,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
286 Lisp_Object file, directory; |
| 153 | 287 { |
|
843
8f6ea998ad0a
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
288 Lisp_Object handler; |
|
8f6ea998ad0a
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
289 |
|
12984
7c38c6da4aae
(Ffile_name_all_completions, Ffile_name_completion):
Richard M. Stallman <rms@gnu.org>
parents:
12244
diff
changeset
|
290 /* If the directory name has special constructs in it, |
|
7c38c6da4aae
(Ffile_name_all_completions, Ffile_name_completion):
Richard M. Stallman <rms@gnu.org>
parents:
12244
diff
changeset
|
291 call the corresponding file handler. */ |
|
14067
afef050ad4e6
(Fdirectory_files, Ffile_name_completion, Ffile_name_all_completions,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
292 handler = Ffind_file_name_handler (directory, Qfile_name_all_completions); |
|
12984
7c38c6da4aae
(Ffile_name_all_completions, Ffile_name_completion):
Richard M. Stallman <rms@gnu.org>
parents:
12244
diff
changeset
|
293 if (!NILP (handler)) |
|
14067
afef050ad4e6
(Fdirectory_files, Ffile_name_completion, Ffile_name_all_completions,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
294 return call3 (handler, Qfile_name_all_completions, file, directory); |
|
12984
7c38c6da4aae
(Ffile_name_all_completions, Ffile_name_completion):
Richard M. Stallman <rms@gnu.org>
parents:
12244
diff
changeset
|
295 |
|
843
8f6ea998ad0a
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
296 /* If the file name has special constructs in it, |
|
8f6ea998ad0a
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
297 call the corresponding file handler. */ |
|
12984
7c38c6da4aae
(Ffile_name_all_completions, Ffile_name_completion):
Richard M. Stallman <rms@gnu.org>
parents:
12244
diff
changeset
|
298 handler = Ffind_file_name_handler (file, Qfile_name_all_completions); |
|
843
8f6ea998ad0a
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
299 if (!NILP (handler)) |
|
14067
afef050ad4e6
(Fdirectory_files, Ffile_name_completion, Ffile_name_all_completions,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
300 return call3 (handler, Qfile_name_all_completions, file, directory); |
|
843
8f6ea998ad0a
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
301 |
|
14067
afef050ad4e6
(Fdirectory_files, Ffile_name_completion, Ffile_name_all_completions,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
302 return file_name_completion (file, directory, 1, 0); |
| 153 | 303 } |
| 304 | |
| 21514 | 305 static int file_name_completion_stat (); |
| 306 | |
| 153 | 307 Lisp_Object |
| 308 file_name_completion (file, dirname, all_flag, ver_flag) | |
| 309 Lisp_Object file, dirname; | |
| 310 int all_flag, ver_flag; | |
| 311 { | |
| 312 DIR *d; | |
| 313 DIRENTRY *dp; | |
| 314 int bestmatchsize, skip; | |
| 315 register int compare, matchsize; | |
| 316 unsigned char *p1, *p2; | |
| 317 int matchcount = 0; | |
| 318 Lisp_Object bestmatch, tem, elt, name; | |
|
19816
902043a3c18a
(ENCODE_FILE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
18666
diff
changeset
|
319 Lisp_Object encoded_file; |
|
902043a3c18a
(ENCODE_FILE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
18666
diff
changeset
|
320 Lisp_Object encoded_dir; |
| 153 | 321 struct stat st; |
| 322 int directoryp; | |
| 323 int passcount; | |
| 324 int count = specpdl_ptr - specpdl; | |
|
19816
902043a3c18a
(ENCODE_FILE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
18666
diff
changeset
|
325 struct gcpro gcpro1, gcpro2, gcpro3, gcpro4, gcpro5; |
|
6559
3d314bef071a
(file_name_completion): Protect things from GC.
Richard M. Stallman <rms@gnu.org>
parents:
5492
diff
changeset
|
326 |
| 153 | 327 #ifdef VMS |
| 328 extern DIRENTRY * readdirver (); | |
| 329 | |
| 330 DIRENTRY *((* readfunc) ()); | |
| 331 | |
| 332 /* Filename completion on VMS ignores case, since VMS filesys does. */ | |
| 333 specbind (Qcompletion_ignore_case, Qt); | |
| 334 | |
| 335 readfunc = readdir; | |
| 336 if (ver_flag) | |
| 337 readfunc = readdirver; | |
| 338 file = Fupcase (file); | |
| 339 #else /* not VMS */ | |
| 340 CHECK_STRING (file, 0); | |
| 341 #endif /* not VMS */ | |
| 342 | |
|
5492
ededb7b52564
(DIRENTRY_NONEMPTY): New macro; two definitions.
Richard M. Stallman <rms@gnu.org>
parents:
5432
diff
changeset
|
343 #ifdef FILE_SYSTEM_CASE |
|
ededb7b52564
(DIRENTRY_NONEMPTY): New macro; two definitions.
Richard M. Stallman <rms@gnu.org>
parents:
5432
diff
changeset
|
344 file = FILE_SYSTEM_CASE (file); |
|
ededb7b52564
(DIRENTRY_NONEMPTY): New macro; two definitions.
Richard M. Stallman <rms@gnu.org>
parents:
5432
diff
changeset
|
345 #endif |
|
6559
3d314bef071a
(file_name_completion): Protect things from GC.
Richard M. Stallman <rms@gnu.org>
parents:
5492
diff
changeset
|
346 bestmatch = Qnil; |
|
19816
902043a3c18a
(ENCODE_FILE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
18666
diff
changeset
|
347 encoded_file = encoded_dir = Qnil; |
|
902043a3c18a
(ENCODE_FILE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
18666
diff
changeset
|
348 GCPRO5 (file, dirname, bestmatch, encoded_file, encoded_dir); |
| 153 | 349 dirname = Fexpand_file_name (dirname, Qnil); |
| 350 | |
|
19816
902043a3c18a
(ENCODE_FILE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
18666
diff
changeset
|
351 /* Do completion on the encoded file name |
|
902043a3c18a
(ENCODE_FILE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
18666
diff
changeset
|
352 because the other names in the directory are (we presume) |
|
902043a3c18a
(ENCODE_FILE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
18666
diff
changeset
|
353 encoded likewise. We decode the completed string at the end. */ |
|
902043a3c18a
(ENCODE_FILE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
18666
diff
changeset
|
354 encoded_file = ENCODE_FILE (file); |
|
902043a3c18a
(ENCODE_FILE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
18666
diff
changeset
|
355 |
|
902043a3c18a
(ENCODE_FILE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
18666
diff
changeset
|
356 encoded_dir = ENCODE_FILE (dirname); |
|
902043a3c18a
(ENCODE_FILE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
18666
diff
changeset
|
357 |
| 153 | 358 /* With passcount = 0, ignore files that end in an ignored extension. |
| 359 If nothing found then try again with passcount = 1, don't ignore them. | |
| 360 If looking for all completions, start with passcount = 1, | |
| 361 so always take even the ignored ones. | |
| 362 | |
| 363 ** It would not actually be helpful to the user to ignore any possible | |
| 364 completions when making a list of them.** */ | |
| 365 | |
| 485 | 366 for (passcount = !!all_flag; NILP (bestmatch) && passcount < 2; passcount++) |
| 153 | 367 { |
|
19816
902043a3c18a
(ENCODE_FILE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
18666
diff
changeset
|
368 d = opendir (XSTRING (Fdirectory_file_name (encoded_dir))->data); |
|
902043a3c18a
(ENCODE_FILE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
18666
diff
changeset
|
369 if (!d) |
| 153 | 370 report_file_error ("Opening directory", Fcons (dirname, Qnil)); |
| 371 | |
| 372 /* Loop reading blocks */ | |
| 373 /* (att3b compiler bug requires do a null comparison this way) */ | |
| 374 while (1) | |
| 375 { | |
| 376 DIRENTRY *dp; | |
| 377 int len; | |
| 378 | |
| 379 #ifdef VMS | |
| 380 dp = (*readfunc) (d); | |
| 381 #else | |
| 382 dp = readdir (d); | |
| 383 #endif | |
| 384 if (!dp) break; | |
| 385 | |
| 386 len = NAMLEN (dp); | |
| 387 | |
| 485 | 388 if (!NILP (Vquit_flag) && NILP (Vinhibit_quit)) |
| 153 | 389 goto quit; |
|
5492
ededb7b52564
(DIRENTRY_NONEMPTY): New macro; two definitions.
Richard M. Stallman <rms@gnu.org>
parents:
5432
diff
changeset
|
390 if (! DIRENTRY_NONEMPTY (dp) |
|
19816
902043a3c18a
(ENCODE_FILE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
18666
diff
changeset
|
391 || len < XSTRING (encoded_file)->size |
|
902043a3c18a
(ENCODE_FILE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
18666
diff
changeset
|
392 || 0 <= scmp (dp->d_name, XSTRING (encoded_file)->data, |
|
902043a3c18a
(ENCODE_FILE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
18666
diff
changeset
|
393 XSTRING (encoded_file)->size)) |
| 153 | 394 continue; |
| 395 | |
|
19816
902043a3c18a
(ENCODE_FILE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
18666
diff
changeset
|
396 if (file_name_completion_stat (encoded_dir, dp, &st) < 0) |
| 153 | 397 continue; |
| 398 | |
| 399 directoryp = ((st.st_mode & S_IFMT) == S_IFDIR); | |
| 400 tem = Qnil; | |
|
9399
dfcf54257f10
(file_name_completion): Ignore files "." and ".." in first pass.
Richard M. Stallman <rms@gnu.org>
parents:
9302
diff
changeset
|
401 if (directoryp) |
|
dfcf54257f10
(file_name_completion): Ignore files "." and ".." in first pass.
Richard M. Stallman <rms@gnu.org>
parents:
9302
diff
changeset
|
402 { |
|
dfcf54257f10
(file_name_completion): Ignore files "." and ".." in first pass.
Richard M. Stallman <rms@gnu.org>
parents:
9302
diff
changeset
|
403 #ifndef TRIVIAL_DIRECTORY_ENTRY |
|
dfcf54257f10
(file_name_completion): Ignore files "." and ".." in first pass.
Richard M. Stallman <rms@gnu.org>
parents:
9302
diff
changeset
|
404 #define TRIVIAL_DIRECTORY_ENTRY(n) (!strcmp (n, ".") || !strcmp (n, "..")) |
|
dfcf54257f10
(file_name_completion): Ignore files "." and ".." in first pass.
Richard M. Stallman <rms@gnu.org>
parents:
9302
diff
changeset
|
405 #endif |
|
dfcf54257f10
(file_name_completion): Ignore files "." and ".." in first pass.
Richard M. Stallman <rms@gnu.org>
parents:
9302
diff
changeset
|
406 /* "." and ".." are never interesting as completions, but are |
|
dfcf54257f10
(file_name_completion): Ignore files "." and ".." in first pass.
Richard M. Stallman <rms@gnu.org>
parents:
9302
diff
changeset
|
407 actually in the way in a directory contains only one file. */ |
|
dfcf54257f10
(file_name_completion): Ignore files "." and ".." in first pass.
Richard M. Stallman <rms@gnu.org>
parents:
9302
diff
changeset
|
408 if (!passcount && TRIVIAL_DIRECTORY_ENTRY (dp->d_name)) |
|
dfcf54257f10
(file_name_completion): Ignore files "." and ".." in first pass.
Richard M. Stallman <rms@gnu.org>
parents:
9302
diff
changeset
|
409 continue; |
|
dfcf54257f10
(file_name_completion): Ignore files "." and ".." in first pass.
Richard M. Stallman <rms@gnu.org>
parents:
9302
diff
changeset
|
410 } |
|
dfcf54257f10
(file_name_completion): Ignore files "." and ".." in first pass.
Richard M. Stallman <rms@gnu.org>
parents:
9302
diff
changeset
|
411 else |
| 153 | 412 { |
| 413 /* Compare extensions-to-be-ignored against end of this file name */ | |
| 414 /* if name is not an exact match against specified string */ | |
|
19816
902043a3c18a
(ENCODE_FILE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
18666
diff
changeset
|
415 if (!passcount && len > XSTRING (encoded_file)->size) |
| 153 | 416 /* and exit this for loop if a match is found */ |
| 417 for (tem = Vcompletion_ignored_extensions; | |
| 418 CONSP (tem); tem = XCONS (tem)->cdr) | |
| 419 { | |
| 420 elt = XCONS (tem)->car; | |
|
9134
37d46d623ed9
(Ffile_name_completion, file_name_completion): Use type test macros.
Karl Heuer <kwzh@gnu.org>
parents:
8800
diff
changeset
|
421 if (!STRINGP (elt)) continue; |
| 153 | 422 skip = len - XSTRING (elt)->size; |
| 423 if (skip < 0) continue; | |
| 424 | |
| 425 if (0 <= scmp (dp->d_name + skip, | |
| 426 XSTRING (elt)->data, | |
| 427 XSTRING (elt)->size)) | |
| 428 continue; | |
| 429 break; | |
| 430 } | |
| 431 } | |
| 432 | |
|
6680
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
433 /* If an ignored-extensions match was found, |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
434 don't process this name as a completion. */ |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
435 if (!passcount && CONSP (tem)) |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
436 continue; |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
437 |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
438 if (!passcount) |
| 153 | 439 { |
|
6680
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
440 Lisp_Object regexps; |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
441 Lisp_Object zero; |
|
9302
4c75b1a56398
(file_name_completion): Don't use XFASTINT as an lvalue.
Karl Heuer <kwzh@gnu.org>
parents:
9171
diff
changeset
|
442 XSETFASTINT (zero, 0); |
| 153 | 443 |
|
6680
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
444 /* Ignore this element if it fails to match all the regexps. */ |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
445 for (regexps = Vcompletion_regexp_list; CONSP (regexps); |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
446 regexps = XCONS (regexps)->cdr) |
| 153 | 447 { |
|
6680
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
448 tem = Fstring_match (XCONS (regexps)->car, elt, zero); |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
449 if (NILP (tem)) |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
450 break; |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
451 } |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
452 if (CONSP (regexps)) |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
453 continue; |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
454 } |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
455 |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
456 /* Update computation of how much all possible completions match */ |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
457 |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
458 matchcount++; |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
459 |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
460 if (all_flag || NILP (bestmatch)) |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
461 { |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
462 /* This is a possible completion */ |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
463 if (directoryp) |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
464 { |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
465 /* This completion is a directory; make it end with '/' */ |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
466 name = Ffile_name_as_directory (make_string (dp->d_name, len)); |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
467 } |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
468 else |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
469 name = make_string (dp->d_name, len); |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
470 if (all_flag) |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
471 { |
|
21050
13e905e1d33c
Include charset.h and coding.h.
Kenichi Handa <handa@m17n.org>
parents:
20870
diff
changeset
|
472 name = DECODE_FILE (name); |
|
6680
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
473 bestmatch = Fcons (name, bestmatch); |
| 153 | 474 } |
| 475 else | |
| 476 { | |
|
6680
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
477 bestmatch = name; |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
478 bestmatchsize = XSTRING (name)->size; |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
479 } |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
480 } |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
481 else |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
482 { |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
483 compare = min (bestmatchsize, len); |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
484 p1 = XSTRING (bestmatch)->data; |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
485 p2 = (unsigned char *) dp->d_name; |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
486 matchsize = scmp(p1, p2, compare); |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
487 if (matchsize < 0) |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
488 matchsize = compare; |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
489 if (completion_ignore_case) |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
490 { |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
491 /* If this is an exact match except for case, |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
492 use it as the best match rather than one that is not |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
493 an exact match. This way, we get the case pattern |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
494 of the actual match. */ |
| 15197 | 495 /* This tests that the current file is an exact match |
| 496 but BESTMATCH is not (it is too long). */ | |
|
6680
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
497 if ((matchsize == len |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
498 && matchsize + !!directoryp |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
499 < XSTRING (bestmatch)->size) |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
500 || |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
501 /* If there is no exact match ignoring case, |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
502 prefer a match that does not change the case |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
503 of the input. */ |
| 15197 | 504 /* If there is more than one exact match aside from |
| 505 case, and one of them is exact including case, | |
| 506 prefer that one. */ | |
| 507 /* This == checks that, of current file and BESTMATCH, | |
| 508 either both or neither are exact. */ | |
|
6680
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
509 (((matchsize == len) |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
510 == |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
511 (matchsize + !!directoryp |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
512 == XSTRING (bestmatch)->size)) |
|
19816
902043a3c18a
(ENCODE_FILE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
18666
diff
changeset
|
513 && !bcmp (p2, XSTRING (encoded_file)->data, XSTRING (encoded_file)->size) |
|
902043a3c18a
(ENCODE_FILE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
18666
diff
changeset
|
514 && bcmp (p1, XSTRING (encoded_file)->data, XSTRING (encoded_file)->size))) |
|
4778
76f267188bbd
(file_name_completion): Install case-preserving changes from Emacs 18
Brian Fox <bfox@gnu.org>
parents:
4696
diff
changeset
|
515 { |
|
6680
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
516 bestmatch = make_string (dp->d_name, len); |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
517 if (directoryp) |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
518 bestmatch = Ffile_name_as_directory (bestmatch); |
|
4778
76f267188bbd
(file_name_completion): Install case-preserving changes from Emacs 18
Brian Fox <bfox@gnu.org>
parents:
4696
diff
changeset
|
519 } |
|
6680
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
520 } |
|
4778
76f267188bbd
(file_name_completion): Install case-preserving changes from Emacs 18
Brian Fox <bfox@gnu.org>
parents:
4696
diff
changeset
|
521 |
|
6680
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
522 /* If this dirname all matches, see if implicit following |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
523 slash does too. */ |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
524 if (directoryp |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
525 && compare == matchsize |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
526 && bestmatchsize > matchsize |
|
9787
c55f03316095
Use macros IS_ANY_SEP, IS_DIRECTORY_SEP, and DIRECTORY_SEP.
Richard M. Stallman <rms@gnu.org>
parents:
9604
diff
changeset
|
527 && IS_ANY_SEP (p1[matchsize])) |
|
6680
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
528 matchsize++; |
|
1cf70b5f6d6d
(file_name_completion): Honor completion-regexp-list.
Karl Heuer <kwzh@gnu.org>
parents:
6565
diff
changeset
|
529 bestmatchsize = matchsize; |
| 153 | 530 } |
| 531 } | |
| 532 closedir (d); | |
| 533 } | |
| 534 | |
|
6559
3d314bef071a
(file_name_completion): Protect things from GC.
Richard M. Stallman <rms@gnu.org>
parents:
5492
diff
changeset
|
535 UNGCPRO; |
|
3d314bef071a
(file_name_completion): Protect things from GC.
Richard M. Stallman <rms@gnu.org>
parents:
5492
diff
changeset
|
536 bestmatch = unbind_to (count, bestmatch); |
| 153 | 537 |
| 485 | 538 if (all_flag || NILP (bestmatch)) |
|
19816
902043a3c18a
(ENCODE_FILE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
18666
diff
changeset
|
539 { |
|
21050
13e905e1d33c
Include charset.h and coding.h.
Kenichi Handa <handa@m17n.org>
parents:
20870
diff
changeset
|
540 if (STRINGP (bestmatch)) |
|
13e905e1d33c
Include charset.h and coding.h.
Kenichi Handa <handa@m17n.org>
parents:
20870
diff
changeset
|
541 bestmatch = DECODE_FILE (bestmatch); |
|
19816
902043a3c18a
(ENCODE_FILE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
18666
diff
changeset
|
542 return bestmatch; |
|
902043a3c18a
(ENCODE_FILE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
18666
diff
changeset
|
543 } |
| 153 | 544 if (matchcount == 1 && bestmatchsize == XSTRING (file)->size) |
| 545 return Qt; | |
|
19816
902043a3c18a
(ENCODE_FILE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
18666
diff
changeset
|
546 bestmatch = Fsubstring (bestmatch, make_number (0), |
|
902043a3c18a
(ENCODE_FILE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
18666
diff
changeset
|
547 make_number (bestmatchsize)); |
|
902043a3c18a
(ENCODE_FILE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
18666
diff
changeset
|
548 /* Now that we got the right initial segment of BESTMATCH, |
|
902043a3c18a
(ENCODE_FILE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
18666
diff
changeset
|
549 decode it from the coding system in use. */ |
|
21050
13e905e1d33c
Include charset.h and coding.h.
Kenichi Handa <handa@m17n.org>
parents:
20870
diff
changeset
|
550 bestmatch = DECODE_FILE (bestmatch); |
|
19816
902043a3c18a
(ENCODE_FILE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
18666
diff
changeset
|
551 return bestmatch; |
|
902043a3c18a
(ENCODE_FILE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
18666
diff
changeset
|
552 |
| 153 | 553 quit: |
| 554 if (d) closedir (d); | |
| 555 Vquit_flag = Qnil; | |
| 556 return Fsignal (Qquit, Qnil); | |
| 557 } | |
| 558 | |
| 21514 | 559 static int |
| 153 | 560 file_name_completion_stat (dirname, dp, st_addr) |
| 561 Lisp_Object dirname; | |
| 562 DIRENTRY *dp; | |
| 563 struct stat *st_addr; | |
| 564 { | |
| 565 int len = NAMLEN (dp); | |
| 566 int pos = XSTRING (dirname)->size; | |
|
7286
15bf025e8f8c
(file_name_completion_stat): Use both lstat and stat.
Richard M. Stallman <rms@gnu.org>
parents:
7028
diff
changeset
|
567 int value; |
| 153 | 568 char *fullname = (char *) alloca (len + pos + 2); |
| 569 | |
|
16246
4e00938cd261
(file_name_completion): Remove code which sets and
Richard M. Stallman <rms@gnu.org>
parents:
16225
diff
changeset
|
570 #ifdef MSDOS |
|
4e00938cd261
(file_name_completion): Remove code which sets and
Richard M. Stallman <rms@gnu.org>
parents:
16225
diff
changeset
|
571 #if __DJGPP__ > 1 |
|
4e00938cd261
(file_name_completion): Remove code which sets and
Richard M. Stallman <rms@gnu.org>
parents:
16225
diff
changeset
|
572 /* Some fields of struct stat are *very* expensive to compute on MS-DOS, |
|
4e00938cd261
(file_name_completion): Remove code which sets and
Richard M. Stallman <rms@gnu.org>
parents:
16225
diff
changeset
|
573 but aren't required here. Avoid computing the following fields: |
|
4e00938cd261
(file_name_completion): Remove code which sets and
Richard M. Stallman <rms@gnu.org>
parents:
16225
diff
changeset
|
574 st_inode, st_size and st_nlink for directories, and the execute bits |
|
4e00938cd261
(file_name_completion): Remove code which sets and
Richard M. Stallman <rms@gnu.org>
parents:
16225
diff
changeset
|
575 in st_mode for non-directory files with non-standard extensions. */ |
|
4e00938cd261
(file_name_completion): Remove code which sets and
Richard M. Stallman <rms@gnu.org>
parents:
16225
diff
changeset
|
576 |
|
4e00938cd261
(file_name_completion): Remove code which sets and
Richard M. Stallman <rms@gnu.org>
parents:
16225
diff
changeset
|
577 unsigned short save_djstat_flags = _djstat_flags; |
|
4e00938cd261
(file_name_completion): Remove code which sets and
Richard M. Stallman <rms@gnu.org>
parents:
16225
diff
changeset
|
578 |
|
4e00938cd261
(file_name_completion): Remove code which sets and
Richard M. Stallman <rms@gnu.org>
parents:
16225
diff
changeset
|
579 _djstat_flags = _STAT_INODE | _STAT_EXEC_MAGIC | _STAT_DIRSIZE; |
|
4e00938cd261
(file_name_completion): Remove code which sets and
Richard M. Stallman <rms@gnu.org>
parents:
16225
diff
changeset
|
580 #endif /* __DJGPP__ > 1 */ |
|
4e00938cd261
(file_name_completion): Remove code which sets and
Richard M. Stallman <rms@gnu.org>
parents:
16225
diff
changeset
|
581 #endif /* MSDOS */ |
|
4e00938cd261
(file_name_completion): Remove code which sets and
Richard M. Stallman <rms@gnu.org>
parents:
16225
diff
changeset
|
582 |
| 153 | 583 bcopy (XSTRING (dirname)->data, fullname, pos); |
| 584 #ifndef VMS | |
|
9787
c55f03316095
Use macros IS_ANY_SEP, IS_DIRECTORY_SEP, and DIRECTORY_SEP.
Richard M. Stallman <rms@gnu.org>
parents:
9604
diff
changeset
|
585 if (!IS_DIRECTORY_SEP (fullname[pos - 1])) |
|
c55f03316095
Use macros IS_ANY_SEP, IS_DIRECTORY_SEP, and DIRECTORY_SEP.
Richard M. Stallman <rms@gnu.org>
parents:
9604
diff
changeset
|
586 fullname[pos++] = DIRECTORY_SEP; |
| 153 | 587 #endif |
| 588 | |
| 589 bcopy (dp->d_name, fullname + pos, len); | |
| 590 fullname[pos + len] = 0; | |
| 591 | |
|
5432
c3677267e74d
(file_name_completion_stat): If have symlinks, use lstat.
Richard M. Stallman <rms@gnu.org>
parents:
4778
diff
changeset
|
592 #ifdef S_IFLNK |
|
7286
15bf025e8f8c
(file_name_completion_stat): Use both lstat and stat.
Richard M. Stallman <rms@gnu.org>
parents:
7028
diff
changeset
|
593 /* We want to return success if a link points to a nonexistent file, |
|
15bf025e8f8c
(file_name_completion_stat): Use both lstat and stat.
Richard M. Stallman <rms@gnu.org>
parents:
7028
diff
changeset
|
594 but we want to return the status for what the link points to, |
|
15bf025e8f8c
(file_name_completion_stat): Use both lstat and stat.
Richard M. Stallman <rms@gnu.org>
parents:
7028
diff
changeset
|
595 in case it is a directory. */ |
|
15bf025e8f8c
(file_name_completion_stat): Use both lstat and stat.
Richard M. Stallman <rms@gnu.org>
parents:
7028
diff
changeset
|
596 value = lstat (fullname, st_addr); |
|
15bf025e8f8c
(file_name_completion_stat): Use both lstat and stat.
Richard M. Stallman <rms@gnu.org>
parents:
7028
diff
changeset
|
597 stat (fullname, st_addr); |
|
15bf025e8f8c
(file_name_completion_stat): Use both lstat and stat.
Richard M. Stallman <rms@gnu.org>
parents:
7028
diff
changeset
|
598 return value; |
|
5432
c3677267e74d
(file_name_completion_stat): If have symlinks, use lstat.
Richard M. Stallman <rms@gnu.org>
parents:
4778
diff
changeset
|
599 #else |
|
16246
4e00938cd261
(file_name_completion): Remove code which sets and
Richard M. Stallman <rms@gnu.org>
parents:
16225
diff
changeset
|
600 value = stat (fullname, st_addr); |
|
4e00938cd261
(file_name_completion): Remove code which sets and
Richard M. Stallman <rms@gnu.org>
parents:
16225
diff
changeset
|
601 #ifdef MSDOS |
|
4e00938cd261
(file_name_completion): Remove code which sets and
Richard M. Stallman <rms@gnu.org>
parents:
16225
diff
changeset
|
602 #if __DJGPP__ > 1 |
|
4e00938cd261
(file_name_completion): Remove code which sets and
Richard M. Stallman <rms@gnu.org>
parents:
16225
diff
changeset
|
603 _djstat_flags = save_djstat_flags; |
|
4e00938cd261
(file_name_completion): Remove code which sets and
Richard M. Stallman <rms@gnu.org>
parents:
16225
diff
changeset
|
604 #endif /* __DJGPP__ > 1 */ |
|
4e00938cd261
(file_name_completion): Remove code which sets and
Richard M. Stallman <rms@gnu.org>
parents:
16225
diff
changeset
|
605 #endif /* MSDOS */ |
|
4e00938cd261
(file_name_completion): Remove code which sets and
Richard M. Stallman <rms@gnu.org>
parents:
16225
diff
changeset
|
606 return value; |
|
4e00938cd261
(file_name_completion): Remove code which sets and
Richard M. Stallman <rms@gnu.org>
parents:
16225
diff
changeset
|
607 #endif /* S_IFLNK */ |
| 153 | 608 } |
| 609 | |
|
1172
c942305917c1
[VMS]: Include string.h, rms.h, rmsdef.h.
Richard M. Stallman <rms@gnu.org>
parents:
847
diff
changeset
|
610 #ifdef VMS |
|
c942305917c1
[VMS]: Include string.h, rms.h, rmsdef.h.
Richard M. Stallman <rms@gnu.org>
parents:
847
diff
changeset
|
611 |
|
c942305917c1
[VMS]: Include string.h, rms.h, rmsdef.h.
Richard M. Stallman <rms@gnu.org>
parents:
847
diff
changeset
|
612 DEFUN ("file-name-all-versions", Ffile_name_all_versions, |
|
c942305917c1
[VMS]: Include string.h, rms.h, rmsdef.h.
Richard M. Stallman <rms@gnu.org>
parents:
847
diff
changeset
|
613 Sfile_name_all_versions, 2, 2, 0, |
|
14067
afef050ad4e6
(Fdirectory_files, Ffile_name_completion, Ffile_name_all_completions,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
614 "Return a list of all versions of file name FILE in directory DIRECTORY.") |
|
afef050ad4e6
(Fdirectory_files, Ffile_name_completion, Ffile_name_all_completions,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
615 (file, directory) |
|
afef050ad4e6
(Fdirectory_files, Ffile_name_completion, Ffile_name_all_completions,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
616 Lisp_Object file, directory; |
|
1172
c942305917c1
[VMS]: Include string.h, rms.h, rmsdef.h.
Richard M. Stallman <rms@gnu.org>
parents:
847
diff
changeset
|
617 { |
|
14067
afef050ad4e6
(Fdirectory_files, Ffile_name_completion, Ffile_name_all_completions,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
618 return file_name_completion (file, directory, 1, 1); |
|
1172
c942305917c1
[VMS]: Include string.h, rms.h, rmsdef.h.
Richard M. Stallman <rms@gnu.org>
parents:
847
diff
changeset
|
619 } |
|
c942305917c1
[VMS]: Include string.h, rms.h, rmsdef.h.
Richard M. Stallman <rms@gnu.org>
parents:
847
diff
changeset
|
620 |
|
c942305917c1
[VMS]: Include string.h, rms.h, rmsdef.h.
Richard M. Stallman <rms@gnu.org>
parents:
847
diff
changeset
|
621 DEFUN ("file-version-limit", Ffile_version_limit, Sfile_version_limit, 1, 1, 0, |
|
c942305917c1
[VMS]: Include string.h, rms.h, rmsdef.h.
Richard M. Stallman <rms@gnu.org>
parents:
847
diff
changeset
|
622 "Return the maximum number of versions allowed for FILE.\n\ |
|
c942305917c1
[VMS]: Include string.h, rms.h, rmsdef.h.
Richard M. Stallman <rms@gnu.org>
parents:
847
diff
changeset
|
623 Returns nil if the file cannot be opened or if there is no version limit.") |
|
c942305917c1
[VMS]: Include string.h, rms.h, rmsdef.h.
Richard M. Stallman <rms@gnu.org>
parents:
847
diff
changeset
|
624 (filename) |
|
c942305917c1
[VMS]: Include string.h, rms.h, rmsdef.h.
Richard M. Stallman <rms@gnu.org>
parents:
847
diff
changeset
|
625 Lisp_Object filename; |
|
c942305917c1
[VMS]: Include string.h, rms.h, rmsdef.h.
Richard M. Stallman <rms@gnu.org>
parents:
847
diff
changeset
|
626 { |
|
c942305917c1
[VMS]: Include string.h, rms.h, rmsdef.h.
Richard M. Stallman <rms@gnu.org>
parents:
847
diff
changeset
|
627 Lisp_Object retval; |
|
c942305917c1
[VMS]: Include string.h, rms.h, rmsdef.h.
Richard M. Stallman <rms@gnu.org>
parents:
847
diff
changeset
|
628 struct FAB fab; |
|
c942305917c1
[VMS]: Include string.h, rms.h, rmsdef.h.
Richard M. Stallman <rms@gnu.org>
parents:
847
diff
changeset
|
629 struct RAB rab; |
|
c942305917c1
[VMS]: Include string.h, rms.h, rmsdef.h.
Richard M. Stallman <rms@gnu.org>
parents:
847
diff
changeset
|
630 struct XABFHC xabfhc; |
|
c942305917c1
[VMS]: Include string.h, rms.h, rmsdef.h.
Richard M. Stallman <rms@gnu.org>
parents:
847
diff
changeset
|
631 int status; |
|
c942305917c1
[VMS]: Include string.h, rms.h, rmsdef.h.
Richard M. Stallman <rms@gnu.org>
parents:
847
diff
changeset
|
632 |
|
c942305917c1
[VMS]: Include string.h, rms.h, rmsdef.h.
Richard M. Stallman <rms@gnu.org>
parents:
847
diff
changeset
|
633 filename = Fexpand_file_name (filename, Qnil); |
|
c942305917c1
[VMS]: Include string.h, rms.h, rmsdef.h.
Richard M. Stallman <rms@gnu.org>
parents:
847
diff
changeset
|
634 fab = cc$rms_fab; |
|
c942305917c1
[VMS]: Include string.h, rms.h, rmsdef.h.
Richard M. Stallman <rms@gnu.org>
parents:
847
diff
changeset
|
635 xabfhc = cc$rms_xabfhc; |
|
c942305917c1
[VMS]: Include string.h, rms.h, rmsdef.h.
Richard M. Stallman <rms@gnu.org>
parents:
847
diff
changeset
|
636 fab.fab$l_fna = XSTRING (filename)->data; |
|
c942305917c1
[VMS]: Include string.h, rms.h, rmsdef.h.
Richard M. Stallman <rms@gnu.org>
parents:
847
diff
changeset
|
637 fab.fab$b_fns = strlen (fab.fab$l_fna); |
|
c942305917c1
[VMS]: Include string.h, rms.h, rmsdef.h.
Richard M. Stallman <rms@gnu.org>
parents:
847
diff
changeset
|
638 fab.fab$l_xab = (char *) &xabfhc; |
|
c942305917c1
[VMS]: Include string.h, rms.h, rmsdef.h.
Richard M. Stallman <rms@gnu.org>
parents:
847
diff
changeset
|
639 status = sys$open (&fab, 0, 0); |
|
c942305917c1
[VMS]: Include string.h, rms.h, rmsdef.h.
Richard M. Stallman <rms@gnu.org>
parents:
847
diff
changeset
|
640 if (status != RMS$_NORMAL) /* Probably non-existent file */ |
|
c942305917c1
[VMS]: Include string.h, rms.h, rmsdef.h.
Richard M. Stallman <rms@gnu.org>
parents:
847
diff
changeset
|
641 return Qnil; |
|
c942305917c1
[VMS]: Include string.h, rms.h, rmsdef.h.
Richard M. Stallman <rms@gnu.org>
parents:
847
diff
changeset
|
642 sys$close (&fab, 0, 0); |
|
c942305917c1
[VMS]: Include string.h, rms.h, rmsdef.h.
Richard M. Stallman <rms@gnu.org>
parents:
847
diff
changeset
|
643 if (xabfhc.xab$w_verlimit == 32767) |
|
c942305917c1
[VMS]: Include string.h, rms.h, rmsdef.h.
Richard M. Stallman <rms@gnu.org>
parents:
847
diff
changeset
|
644 return Qnil; /* No version limit */ |
|
c942305917c1
[VMS]: Include string.h, rms.h, rmsdef.h.
Richard M. Stallman <rms@gnu.org>
parents:
847
diff
changeset
|
645 else |
|
c942305917c1
[VMS]: Include string.h, rms.h, rmsdef.h.
Richard M. Stallman <rms@gnu.org>
parents:
847
diff
changeset
|
646 return make_number (xabfhc.xab$w_verlimit); |
|
c942305917c1
[VMS]: Include string.h, rms.h, rmsdef.h.
Richard M. Stallman <rms@gnu.org>
parents:
847
diff
changeset
|
647 } |
|
c942305917c1
[VMS]: Include string.h, rms.h, rmsdef.h.
Richard M. Stallman <rms@gnu.org>
parents:
847
diff
changeset
|
648 |
|
c942305917c1
[VMS]: Include string.h, rms.h, rmsdef.h.
Richard M. Stallman <rms@gnu.org>
parents:
847
diff
changeset
|
649 #endif /* VMS */ |
|
c942305917c1
[VMS]: Include string.h, rms.h, rmsdef.h.
Richard M. Stallman <rms@gnu.org>
parents:
847
diff
changeset
|
650 |
| 153 | 651 Lisp_Object |
| 652 make_time (time) | |
| 653 int time; | |
| 654 { | |
| 655 return Fcons (make_number (time >> 16), | |
| 656 Fcons (make_number (time & 0177777), Qnil)); | |
| 657 } | |
| 658 | |
| 659 DEFUN ("file-attributes", Ffile_attributes, Sfile_attributes, 1, 1, 0, | |
| 660 "Return a list of attributes of file FILENAME.\n\ | |
| 661 Value is nil if specified file cannot be opened.\n\ | |
| 662 Otherwise, list elements are:\n\ | |
| 663 0. t for directory, string (name linked to) for symbolic link, or nil.\n\ | |
| 664 1. Number of links to file.\n\ | |
| 665 2. File uid.\n\ | |
| 666 3. File gid.\n\ | |
| 667 4. Last access time, as a list of two integers.\n\ | |
| 668 First integer has high-order 16 bits of time, second has low 16 bits.\n\ | |
| 669 5. Last modification time, likewise.\n\ | |
| 670 6. Last status change time, likewise.\n\ | |
|
3707
b00953e22dc3
(Ffile_attributes): Give -1 as size if size won't fit.
Richard M. Stallman <rms@gnu.org>
parents:
3591
diff
changeset
|
671 7. Size in bytes (-1, if number is out of range).\n\ |
| 153 | 672 8. File modes, as a string of ten letters or dashes as in ls -l.\n\ |
| 673 9. t iff file's gid would change if file were deleted and recreated.\n\ | |
| 674 10. inode number.\n\ | |
| 675 11. Device number.\n\ | |
| 676 \n\ | |
|
1509
9675ae1d95c2
* dired.c (find_file_handler): Declare this extern.
Jim Blandy <jimb@redhat.com>
parents:
1173
diff
changeset
|
677 If file does not exist, returns nil.") |
| 153 | 678 (filename) |
| 679 Lisp_Object filename; | |
| 680 { | |
| 681 Lisp_Object values[12]; | |
| 682 Lisp_Object dirname; | |
|
19816
902043a3c18a
(ENCODE_FILE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
18666
diff
changeset
|
683 Lisp_Object encoded; |
| 153 | 684 struct stat s; |
| 685 struct stat sdir; | |
| 686 char modes[10]; | |
|
843
8f6ea998ad0a
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
687 Lisp_Object handler; |
| 153 | 688 |
| 689 filename = Fexpand_file_name (filename, Qnil); | |
|
843
8f6ea998ad0a
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
690 |
|
8f6ea998ad0a
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
691 /* If the file name has special constructs in it, |
|
8f6ea998ad0a
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
692 call the corresponding file handler. */ |
|
7028
6915bf781a38
Pass operation to Ffind_file_name_handler.
Karl Heuer <kwzh@gnu.org>
parents:
6860
diff
changeset
|
693 handler = Ffind_file_name_handler (filename, Qfile_attributes); |
|
843
8f6ea998ad0a
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
694 if (!NILP (handler)) |
|
8f6ea998ad0a
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
695 return call2 (handler, Qfile_attributes, filename); |
|
8f6ea998ad0a
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
696 |
|
19816
902043a3c18a
(ENCODE_FILE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
18666
diff
changeset
|
697 encoded = ENCODE_FILE (filename); |
|
902043a3c18a
(ENCODE_FILE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
18666
diff
changeset
|
698 |
|
902043a3c18a
(ENCODE_FILE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
18666
diff
changeset
|
699 if (lstat (XSTRING (encoded)->data, &s) < 0) |
| 153 | 700 return Qnil; |
| 701 | |
| 702 switch (s.st_mode & S_IFMT) | |
| 703 { | |
| 704 default: | |
| 705 values[0] = Qnil; break; | |
| 706 case S_IFDIR: | |
| 707 values[0] = Qt; break; | |
| 708 #ifdef S_IFLNK | |
| 709 case S_IFLNK: | |
| 710 values[0] = Ffile_symlink_p (filename); break; | |
| 711 #endif | |
| 712 } | |
| 713 values[1] = make_number (s.st_nlink); | |
| 714 values[2] = make_number (s.st_uid); | |
| 715 values[3] = make_number (s.st_gid); | |
| 716 values[4] = make_time (s.st_atime); | |
| 717 values[5] = make_time (s.st_mtime); | |
| 718 values[6] = make_time (s.st_ctime); | |
|
6860
c24ac406a87b
(Ffile_attributes): Cast st_size to int.
Richard M. Stallman <rms@gnu.org>
parents:
6680
diff
changeset
|
719 values[7] = make_number ((int) s.st_size); |
|
3707
b00953e22dc3
(Ffile_attributes): Give -1 as size if size won't fit.
Richard M. Stallman <rms@gnu.org>
parents:
3591
diff
changeset
|
720 /* If the size is out of range, give back -1. */ |
|
b00953e22dc3
(Ffile_attributes): Give -1 as size if size won't fit.
Richard M. Stallman <rms@gnu.org>
parents:
3591
diff
changeset
|
721 if (XINT (values[7]) != s.st_size) |
|
b00953e22dc3
(Ffile_attributes): Give -1 as size if size won't fit.
Richard M. Stallman <rms@gnu.org>
parents:
3591
diff
changeset
|
722 XSETINT (values[7], -1); |
| 153 | 723 filemodestring (&s, modes); |
| 724 values[8] = make_string (modes, 10); | |
| 725 #ifdef BSD4_3 /* Gross kludge to avoid lack of "#if defined(...)" in VMS */ | |
|
3591
507f64624555
Apply typo patches from Paul Eggert.
Jim Blandy <jimb@redhat.com>
parents:
2961
diff
changeset
|
726 #define BSD4_2 /* A new meaning to the term `backwards compatibility' */ |
| 153 | 727 #endif |
| 728 #ifdef BSD4_2 /* file gid will be dir gid */ | |
| 729 dirname = Ffile_name_directory (filename); | |
|
19816
902043a3c18a
(ENCODE_FILE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
18666
diff
changeset
|
730 if (! NILP (dirname)) |
|
902043a3c18a
(ENCODE_FILE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
18666
diff
changeset
|
731 encoded = ENCODE_FILE (dirname); |
|
902043a3c18a
(ENCODE_FILE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
18666
diff
changeset
|
732 if (! NILP (dirname) && stat (XSTRING (encoded)->data, &sdir) == 0) |
| 153 | 733 values[9] = (sdir.st_gid != s.st_gid) ? Qt : Qnil; |
| 734 else /* if we can't tell, assume worst */ | |
| 735 values[9] = Qt; | |
| 736 #else /* file gid will be egid */ | |
| 737 values[9] = (s.st_gid != getegid ()) ? Qt : Qnil; | |
| 738 #endif /* BSD4_2 (or BSD4_3) */ | |
| 739 #ifdef BSD4_3 | |
| 740 #undef BSD4_2 /* ok, you can look again without throwing up */ | |
| 741 #endif | |
|
18666
e97df3d7af25
(Ffile_attributes): Use cast to avoid warnings.
Richard M. Stallman <rms@gnu.org>
parents:
17868
diff
changeset
|
742 /* Cast -1 to avoid warning if int is not as wide as VALBITS. */ |
|
e97df3d7af25
(Ffile_attributes): Use cast to avoid warnings.
Richard M. Stallman <rms@gnu.org>
parents:
17868
diff
changeset
|
743 if (s.st_ino & (((EMACS_INT) (-1)) << VALBITS)) |
|
17868
bc2cf7c40435
(Ffile_attributes): Return inode number as a cons only if necessary.
Richard M. Stallman <rms@gnu.org>
parents:
17460
diff
changeset
|
744 /* To allow inode numbers larger than VALBITS, separate the bottom |
|
bc2cf7c40435
(Ffile_attributes): Return inode number as a cons only if necessary.
Richard M. Stallman <rms@gnu.org>
parents:
17460
diff
changeset
|
745 16 bits. */ |
|
bc2cf7c40435
(Ffile_attributes): Return inode number as a cons only if necessary.
Richard M. Stallman <rms@gnu.org>
parents:
17460
diff
changeset
|
746 values[10] = Fcons (make_number (s.st_ino >> 16), |
|
bc2cf7c40435
(Ffile_attributes): Return inode number as a cons only if necessary.
Richard M. Stallman <rms@gnu.org>
parents:
17460
diff
changeset
|
747 make_number (s.st_ino & 0xffff)); |
|
bc2cf7c40435
(Ffile_attributes): Return inode number as a cons only if necessary.
Richard M. Stallman <rms@gnu.org>
parents:
17460
diff
changeset
|
748 else |
|
bc2cf7c40435
(Ffile_attributes): Return inode number as a cons only if necessary.
Richard M. Stallman <rms@gnu.org>
parents:
17460
diff
changeset
|
749 /* But keep the most common cases as integers. */ |
|
bc2cf7c40435
(Ffile_attributes): Return inode number as a cons only if necessary.
Richard M. Stallman <rms@gnu.org>
parents:
17460
diff
changeset
|
750 values[10] = make_number (s.st_ino); |
| 153 | 751 values[11] = make_number (s.st_dev); |
| 752 return Flist (sizeof(values) / sizeof(values[0]), values); | |
| 753 } | |
| 754 | |
| 21514 | 755 void |
| 153 | 756 syms_of_dired () |
| 757 { | |
|
843
8f6ea998ad0a
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
758 Qdirectory_files = intern ("directory-files"); |
|
8f6ea998ad0a
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
759 Qfile_name_completion = intern ("file-name-completion"); |
|
8f6ea998ad0a
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
760 Qfile_name_all_completions = intern ("file-name-all-completions"); |
| 847 | 761 Qfile_attributes = intern ("file-attributes"); |
|
843
8f6ea998ad0a
*** empty log message ***
Richard M. Stallman <rms@gnu.org>
parents:
808
diff
changeset
|
762 |
|
16225
ec322e4ffa16
(syms_of_dired): staticpro Qdirectory_files, Qfile_name_completion,
Erik Naggum <erik@naggum.no>
parents:
15626
diff
changeset
|
763 staticpro (&Qdirectory_files); |
|
ec322e4ffa16
(syms_of_dired): staticpro Qdirectory_files, Qfile_name_completion,
Erik Naggum <erik@naggum.no>
parents:
15626
diff
changeset
|
764 staticpro (&Qfile_name_completion); |
|
ec322e4ffa16
(syms_of_dired): staticpro Qdirectory_files, Qfile_name_completion,
Erik Naggum <erik@naggum.no>
parents:
15626
diff
changeset
|
765 staticpro (&Qfile_name_all_completions); |
|
ec322e4ffa16
(syms_of_dired): staticpro Qdirectory_files, Qfile_name_completion,
Erik Naggum <erik@naggum.no>
parents:
15626
diff
changeset
|
766 staticpro (&Qfile_attributes); |
|
ec322e4ffa16
(syms_of_dired): staticpro Qdirectory_files, Qfile_name_completion,
Erik Naggum <erik@naggum.no>
parents:
15626
diff
changeset
|
767 |
| 153 | 768 defsubr (&Sdirectory_files); |
| 769 defsubr (&Sfile_name_completion); | |
| 770 #ifdef VMS | |
| 771 defsubr (&Sfile_name_all_versions); | |
|
1172
c942305917c1
[VMS]: Include string.h, rms.h, rmsdef.h.
Richard M. Stallman <rms@gnu.org>
parents:
847
diff
changeset
|
772 defsubr (&Sfile_version_limit); |
| 153 | 773 #endif /* VMS */ |
| 774 defsubr (&Sfile_name_all_completions); | |
| 775 defsubr (&Sfile_attributes); | |
| 776 | |
| 777 #ifdef VMS | |
| 778 Qcompletion_ignore_case = intern ("completion-ignore-case"); | |
| 779 staticpro (&Qcompletion_ignore_case); | |
| 780 #endif /* VMS */ | |
| 781 | |
| 782 DEFVAR_LISP ("completion-ignored-extensions", &Vcompletion_ignored_extensions, | |
| 783 "*Completion ignores filenames ending in any string in this list.\n\ | |
| 784 This variable does not affect lists of possible completions,\n\ | |
| 785 but does affect the commands that actually do completions."); | |
| 786 Vcompletion_ignored_extensions = Qnil; | |
| 787 } |
