ls.c revision 1.1 1 /*-
2 * Copyright (c) 1993
3 * The Regents of the University of California. All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 * 1. Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer.
10 * 2. Redistributions in binary form must reproduce the above copyright
11 * notice, this list of conditions and the following disclaimer in the
12 * documentation and/or other materials provided with the distribution.
13 * 3. All advertising materials mentioning features or use of this software
14 * must display the following acknowledgement:
15 * This product includes software developed by the University of
16 * California, Berkeley and its contributors.
17 * 4. Neither the name of the University nor the names of its contributors
18 * may be used to endorse or promote products derived from this software
19 * without specific prior written permission.
20 *
21 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
22 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
23 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
24 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
25 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
26 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
27 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
28 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
29 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
30 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
31 * SUCH DAMAGE.
32 */
33
34 #ifndef lint
35 static char copyright[] =
36 "@(#) Copyright (c) 1993\n\
37 The Regents of the University of California. All rights reserved.\n";
38 #endif /* not lint */
39
40 #ifndef lint
41 /* From:
42 static char sccsid[] = "@(#)ls.c 8.1 (Berkeley) 6/11/93"; */
43 static char rcsid[] = "$Id: ls.c,v 1.1 1994/01/26 02:03:50 brezak Exp $";
44 #endif /* not lint */
45
46 #include <sys/param.h>
47 #include <ufs/dir.h>
48 #include <sys/ttychars.h>
49 #include "stand.h"
50
51 main()
52 {
53 struct dinode *ip;
54 int fd;
55
56 for (;;) {
57 if ((fd = getfile("ls", 0)) == -1)
58 exit();
59 ip = &iob[fd - 3].i_ino;
60 if ((ip->di_mode & IFMT) != IFDIR) {
61 printf("ls: not a directory\n");
62 continue;
63 }
64 if (ip->di_size == 0) {
65 printf("ls: zero length directory\n");
66 continue;
67 }
68 ls(fd);
69 }
70 }
71
72 #define CTRL(x) (x&037)
73
74 getfile(prompt, mode)
75 char *prompt;
76 int mode;
77 {
78 int fd;
79 char buf[100];
80
81 do {
82 printf("%s: ", prompt);
83 gets(buf);
84 if (buf[0] == CTRL('d') && buf[1] == 0)
85 return (-1);
86 } while ((fd = open(buf, mode)) < 0);
87 return(fd);
88 }
89
90 typedef struct direct DP;
91 static
92 ls(fd)
93 register int fd;
94 {
95 register int size;
96 register char *dp;
97 char dirbuf[DIRBLKSIZ];
98
99 printf("\ninode\tname\n");
100 while ((size = read(fd, dirbuf, DIRBLKSIZ)) == DIRBLKSIZ)
101 for (dp = dirbuf; (dp < (dirbuf + size)) &&
102 (dp + ((DP *)dp)->d_reclen) < (dirbuf + size);
103 dp += ((DP *)dp)->d_reclen) {
104 if (((DP *)dp)->d_ino == 0)
105 continue;
106 if (((DP *)dp)->d_namlen > MAXNAMLEN+1) {
107 printf("Corrupt file name length! Run fsck soon!\n");
108 return;
109 }
110 printf("%d\t%s\n", ((DP *)dp)->d_ino,
111 ((DP *)dp)->d_name);
112 }
113 }
114