diff options
author | andersen <andersen@69ca8d6d-28ef-0310-b511-8ec308f3f277> | 2001-05-04 22:04:24 +0000 |
---|---|---|
committer | andersen <andersen@69ca8d6d-28ef-0310-b511-8ec308f3f277> | 2001-05-04 22:04:24 +0000 |
commit | b371eec2dfdb5882be87ecb3031a0d056a4c7cee (patch) | |
tree | 18212b9982894cbb0bafa7a675e9cc7f0fa6e3c3 /which.c | |
parent | 563296f0af9292a0285cdff2e5ccb0e84e186756 (diff) | |
download | busybox-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.c | 7 |
1 files changed, 3 insertions, 4 deletions
@@ -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 | { |