aboutsummaryrefslogtreecommitdiff
path: root/which.c
diff options
context:
space:
mode:
authorandersen <andersen@69ca8d6d-28ef-0310-b511-8ec308f3f277>2001-05-04 22:04:24 +0000
committerandersen <andersen@69ca8d6d-28ef-0310-b511-8ec308f3f277>2001-05-04 22:04:24 +0000
commitb371eec2dfdb5882be87ecb3031a0d056a4c7cee (patch)
tree18212b9982894cbb0bafa7a675e9cc7f0fa6e3c3 /which.c
parent563296f0af9292a0285cdff2e5ccb0e84e186756 (diff)
downloadbusybox-w32-b371eec2dfdb5882be87ecb3031a0d056a4c7cee.tar.gz
busybox-w32-b371eec2dfdb5882be87ecb3031a0d056a4c7cee.tar.bz2
busybox-w32-b371eec2dfdb5882be87ecb3031a0d056a4c7cee.zip
Larry suggested using concat_path_file() would be an even safer bet
for 'which'. I ageed, so I whipped this up -- which revealed a bug in concat_path_file. It turns out that that a '/' can be appended from either the path _or_ the filename, but only the former was checked. -Erik git-svn-id: svn://busybox.net/trunk/busybox@2536 69ca8d6d-28ef-0310-b511-8ec308f3f277
Diffstat (limited to '')
-rw-r--r--which.c7
1 files changed, 3 insertions, 4 deletions
diff --git a/which.c b/which.c
index 08813c149..1e5e9eed5 100644
--- a/which.c
+++ b/which.c
@@ -53,10 +53,9 @@ extern int which_main(int argc, char **argv)
53 argv++; 53 argv++;
54 found = 0; 54 found = 0;
55 for (i = 0; i < count; i++) { 55 for (i = 0; i < count; i++) {
56 char buf[strlen(path_n)+strlen(*argv)+2]; 56 char *buf;
57 strcpy (buf, path_n); 57 buf = concat_path_file(buf, path_n);
58 strcat (buf, "/"); 58 buf = concat_path_file(buf, *argv);
59 strcat (buf, *argv);
60 if (stat (buf, &filestat) == 0 59 if (stat (buf, &filestat) == 0
61 && filestat.st_mode & S_IXUSR) 60 && filestat.st_mode & S_IXUSR)
62 { 61 {