1 /* $NetBSD: ls.c,v 1.5 2014/03/20 03:13:18 christos Exp $ */
5 * The NetBSD Foundation, Inc. All rights reserved.
7 * This code is derived from software contributed to The NetBSD Foundation
10 * Redistribution and use in source and binary forms, with or without
11 * modification, are permitted provided that the following conditions
13 * 1. Redistributions of source code must retain the above copyright
14 * notice, this list of conditions and the following disclaimer.
15 * 2. Redistributions in binary form must reproduce the above copyright
16 * notice, this list of conditions and the following disclaimer in the
17 * documentation and/or other materials provided with the distribution.
19 * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
20 * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
21 * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
22 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
23 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29 * POSSIBILITY OF SUCH DAMAGE.
34 * The Regents of the University of California. All rights reserved.
36 * Redistribution and use in source and binary forms, with or without
37 * modification, are permitted provided that the following conditions
39 * 1. Redistributions of source code must retain the above copyright
40 * notice, this list of conditions and the following disclaimer.
41 * 2. Redistributions in binary form must reproduce the above copyright
42 * notice, this list of conditions and the following disclaimer in the
43 * documentation and/or other materials provided with the distribution.
44 * 3. Neither the name of the University nor the names of its contributors
45 * may be used to endorse or promote products derived from this software
46 * without specific prior written permission.
48 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
49 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
50 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
51 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
52 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
53 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
54 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
55 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
56 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
57 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
63 * Matthias Drochner. All rights reserved.
65 * Redistribution and use in source and binary forms, with or without
66 * modification, are permitted provided that the following conditions
68 * 1. Redistributions of source code must retain the above copyright
69 * notice, this list of conditions and the following disclaimer.
70 * 2. Redistributions in binary form must reproduce the above copyright
71 * notice, this list of conditions and the following disclaimer in the
72 * documentation and/or other materials provided with the distribution.
74 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
75 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
76 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
77 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
78 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
79 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
80 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
81 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
82 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
83 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
89 #if defined(__minix) && defined(LIBSA_ENABLE_LOAD_MODS_OP)
90 #include <sys/param.h>
91 #endif /* defined(__minix) && defined(LIBSA_ENABLE_LOAD_MODS_OP) */
93 #include <lib/libkern/libkern.h>
97 #if defined(__minix) && defined(LIBSA_ENABLE_LOAD_MODS_OP)
99 load_mods(path
, NULL
);
103 load_mods(const char *path
, void (*funcp
)(char* arg
))
105 #endif /* !defined(__minix) && defined(LIBSA_ENABLE_LOAD_MODS_OP) */
108 #if defined(__minix) && defined(LIBSA_ENABLE_LOAD_MODS_OP)
112 #endif /* !defined(__minix) && defined(LIBSA_ENABLE_LOAD_MODS_OP) */
114 const char *fname
= 0;
115 #if defined(__minix) && defined(LIBSA_ENABLE_LOAD_MODS_OP)
119 #endif /* !defined(__minix) && defined(LIBSA_ENABLE_LOAD_MODS_OP) */
122 if ((fd
= open(path
, 0)) < 0
123 || fstat(fd
, &sb
) < 0
124 || (sb
.st_mode
& S_IFMT
) != S_IFDIR
) {
125 /* Path supplied isn't a directory, open parent
126 directory and list matching files. */
129 fname
= strrchr(path
, '/');
136 memcpy(p
, path
, size
);
139 #if defined(__minix) && !defined(LIBSA_ENABLE_LOAD_MODS_OP)
140 dealloc(p
, size
+ 1);
141 #endif /* !defined(__minix) && !defined(LIBSA_ENABLE_LOAD_MODS_OP) */
148 printf("ls: %s\n", strerror(errno
));
151 if (fstat(fd
, &sb
) < 0) {
152 printf("stat: %s\n", strerror(errno
));
155 if ((sb
.st_mode
& S_IFMT
) != S_IFDIR
) {
156 printf("%s: %s\n", path
, strerror(ENOTDIR
));
163 #if !defined(LIBSA_NO_FD_CHECKING)
164 if ((unsigned int)fd
>= SOPEN_MAX
|| f
->f_flags
== 0) {
170 #if !defined(LIBSA_NO_RAW_ACCESS)
171 /* operation not defined on raw devices */
172 if (f
->f_flags
& F_RAW
) {
178 if (FS_LS(f
->f_ops
) != NULL
)
179 #if defined(__minix) && defined(LIBSA_ENABLE_LOAD_MODS_OP)
180 FS_LOAD_MODS(f
->f_ops
)(f
, fname
, funcp
, p
);
182 FS_LS(f
->f_ops
)(f
, fname
);
183 #endif /* !defined(__minix) && defined(LIBSA_ENABLE_LOAD_MODS_OP) */
185 printf("no ls support for this file system\n");
188 #if defined(__minix) && defined(LIBSA_ENABLE_LOAD_MODS_OP)
189 /* LSC: MINIX Modification for correct glob support, beware! */
191 dealloc(p
, size
+ 1);
192 #endif /* !defined(__minix) && defined(LIBSA_ENABLE_LOAD_MODS_OP) */
197 struct lsentry
*e_next
;
204 lsadd(lsentry_t
**names
, const char *pattern
, const char *name
, size_t namelen
,
205 uint32_t ino
, const char *type
)
209 if (pattern
&& !fnmatch(name
, pattern
))
212 n
= alloc(sizeof *n
+ namelen
);
214 printf("%d: %.*s (%s)\n", ino
, (int)namelen
, name
, type
);
220 memcpy(n
->e_name
, name
, namelen
);
221 n
->e_name
[namelen
] = '\0';
223 for (np
= names
; *np
; np
= &(*np
)->e_next
) {
224 if (strcmp(n
->e_name
, (*np
)->e_name
) < 0)
231 #if defined(__minix) && defined(LIBSA_ENABLE_LOAD_MODS_OP)
233 lsapply(lsentry_t
* names
, const char * pattern
, void (* funcp
)(char * arg
),
237 printf("not found\n");
241 printf("no callback provided\n");
245 lsentry_t
*n
= names
;
246 char namebuf
[MAXPATHLEN
+1];
249 if (path
!= pattern
) {
250 strcpy(namebuf
, path
);
251 namebuf
[strlen(path
)] = '/';
252 namebuf
[strlen(path
) + 1] = '\0';
254 strcat(namebuf
, n
->e_name
);
261 #endif /* !defined(__minix) && defined(LIBSA_ENABLE_LOAD_MODS_OP) */
264 load_modsunsup(const char *name
) {
265 printf("The load_mods command is not currently supported for %s\n", name
);
267 #endif /* defined(__minix) */
270 lsprint(lsentry_t
*names
) {
272 printf("not found\n");
276 lsentry_t
*n
= names
;
277 printf("%d: %s (%s)\n", n
->e_ino
, n
->e_name
, n
->e_type
);
283 lsfree(lsentry_t
*names
) {
287 lsentry_t
*n
= names
;
294 lsunsup(const char *name
) {
295 printf("The ls command is not currently supported for %s\n", name
);