summaryrefslogtreecommitdiff
path: root/ls.c
diff options
context:
space:
mode:
authorrsc <rsc>2007-08-22 05:57:39 +0000
committerrsc <rsc>2007-08-22 05:57:39 +0000
commit3dcf889c1b5c2c5ddf5b4756f2a731c344f6f08e (patch)
tree3d03cf0af8b59ef02a52fca37b80ae2fcaa8eae7 /ls.c
parent6bf2e5c898db477300189de1a5083a9692a6cbb6 (diff)
downloadxv6-labs-3dcf889c1b5c2c5ddf5b4756f2a731c344f6f08e.tar.gz
xv6-labs-3dcf889c1b5c2c5ddf5b4756f2a731c344f6f08e.tar.bz2
xv6-labs-3dcf889c1b5c2c5ddf5b4756f2a731c344f6f08e.zip
cleanup
Diffstat (limited to 'ls.c')
-rw-r--r--ls.c26
1 files changed, 12 insertions, 14 deletions
diff --git a/ls.c b/ls.c
index 3a29a75..cf22a45 100644
--- a/ls.c
+++ b/ls.c
@@ -3,10 +3,6 @@
#include "user.h"
#include "fs.h"
-char buf[512];
-struct stat st;
-struct dirent dirent;
-
void
pname(char *n)
{
@@ -22,10 +18,11 @@ pname(char *n)
int
main(int argc, char *argv[])
{
+ char buf[512], *p;
int fd;
- uint off;
- uint sz;
- char *p;
+ uint off, sz;
+ struct dirent de;
+ struct stat st;
if(argc > 2){
puts("Usage: ls [dir]\n");
@@ -58,12 +55,12 @@ main(int argc, char *argv[])
break;
case T_DIR:
sz = st.size;
- for(off = 0; off < sz; off += sizeof(struct dirent)) {
- if(read(fd, &dirent, sizeof dirent) != sizeof dirent) {
+ for(off = 0; off < sz; off += sizeof(de)) {
+ if(read(fd, &de, sizeof(de)) != sizeof(de)) {
printf(1, "ls: read error\n");
break;
}
- if(dirent.inum != 0) {
+ if(de.inum != 0) {
p = buf;
if(argc == 2) {
strcpy(p, argv[1]);
@@ -71,13 +68,14 @@ main(int argc, char *argv[])
if(*(p-1) != '/')
*p++ = '/';
}
- strcpy(p, dirent.name);
+ memmove(p, de.name, DIRSIZ);
+ p[DIRSIZ] = 0;
if(stat(buf, &st) < 0) {
- printf(1, "stat: failed %s\n", dirent.name);
+ printf(1, "stat: failed %s\n", de.name);
continue;
}
- pname(dirent.name);
- printf(1, "%d %d %d\n", st.type, dirent.inum, st.size);
+ pname(de.name);
+ printf(1, "%d %d %d\n", st.type, de.inum, st.size);
}
}
break;