aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--man/man1/test.17
-rw-r--r--src/cmd/test.c155
2 files changed, 84 insertions, 78 deletions
diff --git a/man/man1/test.1 b/man/man1/test.1
index ec017918..9957b29d 100644
--- a/man/man1/test.1
+++ b/man/man1/test.1
@@ -209,3 +209,10 @@ is in the current directory.
.B \*9/src/cmd/test.c
.SH "SEE ALSO"
.IR rc (1)
+.SH BUGS
+Won't complain about extraneous arguments
+since there may be arguments left unprocessed by
+short-circuit evaluation of
+.B -a
+or
+.BR -o .
diff --git a/src/cmd/test.c b/src/cmd/test.c
index 6ab01b18..b782df76 100644
--- a/src/cmd/test.c
+++ b/src/cmd/test.c
@@ -230,92 +230,77 @@ tio(char *a, int f)
return access (a, f) >= 0;
}
-/* copy to local memory; clear names for safety */
-int
-localstat(char *f, Dir *dir)
-{
- Dir *d;
-
- d = dirstat(f);
- if(d == nil)
- return(-1);
- *dir = *d;
- free(d);
- dir->name = 0;
- dir->uid = 0;
- dir->gid = 0;
- dir->muid = 0;
- return 0;
-}
-
-/* copy to local memory; clear names for safety */
-int
-localfstat(int f, Dir *dir)
-{
- Dir *d;
-
- d = dirfstat(f);
- if(d == nil)
- return(-1);
- *dir = *d;
- free(d);
- dir->name = 0;
- dir->uid = 0;
- dir->gid = 0;
- dir->muid = 0;
- return 0;
-}
+/*
+ * note that the name strings pointed to by Dir members are
+ * allocated with the Dir itself (by the same call to malloc),
+ * but are not included in sizeof(Dir), so copying a Dir won't
+ * copy the strings it points to.
+ */
int
hasmode(char *f, ulong m)
{
- Dir dir;
+ int r;
+ Dir *dir;
- if(localstat(f,&dir)<0)
- return(0);
- return(dir.mode&m);
+ dir = dirstat(f);
+ if (dir == nil)
+ return 0;
+ r = (dir->mode & m) != 0;
+ free(dir);
+ return r;
}
int
isdir(char *f)
{
- Dir dir;
-
- if(localstat(f,&dir)<0)
- return(0);
- return(dir.mode&DMDIR);
+ return hasmode(f, DMDIR);
}
int
isreg(char *f)
{
- Dir dir;
+ int r;
+ Dir *dir;
- if(localstat(f,&dir)<0)
- return(0);
- return(!(dir.mode&DMDIR));
+ dir = dirstat(f);
+ if (dir == nil)
+ return 0;
+ r = (dir->mode & DMDIR) == 0;
+ free(dir);
+ return r;
}
int
isatty(int fd)
{
- Dir d1, d2;
-
- if(localfstat(fd, &d1) < 0)
- return 0;
- if(localstat("/dev/cons", &d2) < 0)
- return 0;
- return d1.type==d2.type && d1.dev==d2.dev && d1.qid.path==d2.qid.path;
+ int r;
+ Dir *d1, *d2;
+
+ d1 = dirfstat(fd);
+ d2 = dirstat("/dev/cons");
+ if (d1 == nil || d2 == nil)
+ r = 0;
+ else
+ r = d1->type == d2->type && d1->dev == d2->dev &&
+ d1->qid.path == d2->qid.path;
+ free(d1);
+ free(d2);
+ return r;
}
int
fsizep(char *f)
{
- Dir dir;
+ int r;
+ Dir *dir;
- if(localstat(f,&dir)<0)
- return(0);
- return(dir.length>0);
+ dir = dirstat(f);
+ if (dir == nil)
+ return 0;
+ r = dir->length > 0;
+ free(dir);
+ return r;
}
void
@@ -344,12 +329,14 @@ isint(char *s, int *pans)
int
isolder(char *pin, char *f)
{
- char *p = pin;
+ int r;
ulong n, m;
- Dir dir;
+ char *p = pin;
+ Dir *dir;
- if(localstat(f,&dir)<0)
- return(0);
+ dir = dirstat(f);
+ if (dir == nil)
+ return 0;
/* parse time */
n = 0;
@@ -383,29 +370,41 @@ isolder(char *pin, char *f)
}
}
- return(dir.mtime+n < time(0));
+ r = dir->mtime + n < time(0);
+ free(dir);
+ return r;
}
int
isolderthan(char *a, char *b)
{
- Dir ad, bd;
-
- if(localstat(a, &ad)<0)
- return(0);
- if(localstat(b, &bd)<0)
- return(0);
- return ad.mtime > bd.mtime;
+ int r;
+ Dir *ad, *bd;
+
+ ad = dirstat(a);
+ bd = dirstat(b);
+ if (ad == nil || bd == nil)
+ r = 0;
+ else
+ r = ad->mtime > bd->mtime;
+ free(ad);
+ free(bd);
+ return r;
}
int
isnewerthan(char *a, char *b)
{
- Dir ad, bd;
-
- if(localstat(a, &ad)<0)
- return(0);
- if(localstat(b, &bd)<0)
- return(0);
- return ad.mtime < bd.mtime;
+ int r;
+ Dir *ad, *bd;
+
+ ad = dirstat(a);
+ bd = dirstat(b);
+ if (ad == nil || bd == nil)
+ r = 0;
+ else
+ r = ad->mtime < bd->mtime;
+ free(ad);
+ free(bd);
+ return r;
}