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