On Fri, Aug 12, 2011 at 01:55:42PM -0400, Davidlohr Bueso wrote: > misc-utils/whereis.c | 69 +++++++++++++++++++++++++++++++++++++++++++++++++- > 1 files changed, 68 insertions(+), 1 deletions(-) Applied, thanks. ...but: $ whereis -m git-rm-commit git-rm-commit: /home/kzak/bin/git-rm-commit the -m means "man pages only", but the result is executable file. I have fixed this problem, the $PATH is used for binaries only and ignored if -B is specified. See below. Karel >From 4ff826f68a7d9bd1239644ab53be9b81fc8b7a37 Mon Sep 17 00:00:00 2001 From: Karel Zak <kzak@xxxxxxxxxx> Date: Tue, 30 Aug 2011 11:44:15 +0200 Subject: [PATCH] whereis: search in path for binaries only Signed-off-by: Karel Zak <kzak@xxxxxxxxxx> --- misc-utils/whereis.c | 15 ++++++++------- 1 files changed, 8 insertions(+), 7 deletions(-) diff --git a/misc-utils/whereis.c b/misc-utils/whereis.c index 90f7b90..03ea95e 100644 --- a/misc-utils/whereis.c +++ b/misc-utils/whereis.c @@ -299,8 +299,6 @@ findv(char **dirv, int dirc, char *cp) while (dirc > 0) findin(*dirv++, cp), dirc--; - while (*dirp) - findin(*dirp++, cp); } static void @@ -315,9 +313,11 @@ looksrc(char *cp) static void lookbin(char *cp) { - if (Bflag == 0) + if (Bflag == 0) { findv(bindirs, ARRAY_SIZE(bindirs)-1, cp); - else + while (*dirp) + findin(*dirp++, cp); /* look $PATH */ + } else findv(Bflag, Bcnt, cp); } @@ -424,8 +424,6 @@ main(int argc, char **argv) if (argc == 0) usage(stderr); - fillpath(); - do if (argv[0][0] == '-') { register char *cp = argv[0] + 1; @@ -475,8 +473,11 @@ main(int argc, char **argv) usage(stderr); } argv++; - } else + } else { + if (Bcnt == 0 && pathdir == NULL) + fillpath(); lookup(*argv++); + } while (--argc > 0); freepath(); -- 1.7.6 -- To unsubscribe from this list: send the line "unsubscribe util-linux" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html