mxcl
mxcl

Reputation: 26913

How can I make the "find" Command on OS X default to the current directory?

I am a heavy command line user and use the find command extensively in my build system scripts. However on Mac OS X when I am not concentrating I often get output like this:

$ find -name \*.plist
find: illegal option -- n
find: illegal option -- a
find: illegal option -- m
find: illegal option -- e
find: *.plist: No such file or directory

Basically, I forgot to add the little dot:

$ find . -name \*.plist

Because BSD find requires the path and GNU find doesn't (it assumes the current directory if you don't specify one). I use Linux, Mac OS X and Cygwin often all at the same time, so it's of great benefit to me to have all my tools behave the same. I tried writing a bash find function that added "./" if I forgot, but I failed. Thanks for your help. :)

Upvotes: 15

Views: 16772

Answers (7)

Pysis
Pysis

Reputation: 1606

You may want to run the commands found in this link: https://www.topbug.net/blog/2013/04/14/install-and-use-gnu-command-line-tools-in-mac-os-x/

It is a bit outdated, for example I found I did not have to add many commands to my path at all.

This covers your problem by having your system use the Non-BSD find utility from the findutils package, while also installing other tools you may want as well.

Upvotes: 1

odinho - Velmont
odinho - Velmont

Reputation: 21524

Install GNU find instead.

$ brew install findutils
$ alias find=gfind

Yay, it works!

Upvotes: 22

Jonathan Leffler
Jonathan Leffler

Reputation: 755094

If you can't discipline yourself to use find 'correctly', then why not install GNU find (from findutils) in a directory on your PATH ahead of the system find command.

I used to have my own private variant of cp that would copy files to the current directory if the last item in the list was not a directory. I kept that in my personal bin directory for many years - but eventually removed it because I no longer used the functionality. (My 'cp.sh' was written in 1987 and edited twice, in 1990 and 1997, as part of changes to version control system notations. I think I removed it around 1998. The primary problem with the script is that cp file1 file2 is ambiguous between copying a file over another and copying two files to the current directory.)

Consider writing your own wrapper to find:

#!/bin/sh
[ ! -d "$1" ] && set -- . "$@"
exec /usr/bin/find "$@"

The second line says "if argument 1 is not a directory, then adjust the command line arguments to include dot ahead of the rest of the command. That will be confusing if you ever type:

~/bin/find /non-existent/directory -name '*.plist' -print

because the non-existent directory isn't a directory and the script will add dot to the command line -- the sort of reason that I stopped using my private cp command.

Upvotes: 11

Owen
Owen

Reputation: 84593

find ./ -name "*.plist"

edit: hmm, i may have misunderstood the question! if you were crazy, how about emulating it via a shell script? i routinely keep random utility scripts in ~/.bin, and that's the first thing in my PATH. if you had a similar setup perhaps you could do something like: (untested!)

#!/bin/sh
# remapping find!
CMD=`echo $1 | cut -c 1`
if [ $CMD = '-' ]
then
# pwd search
  /usr/bin/find ./ $*
else
# regular find
  /usr/bin/find $*
fi

Upvotes: 4

tzot
tzot

Reputation: 96081

If you must call it 'find', then you want:

alias find=/usr/bin/find\ .

in your .profile or .bash_profile or …. Substitute the real path (if not /usr/bin/find) on your Mac OSX. Enter the full path to avoid cycles (bash normally would interpret alias find=find without issues, but better be sure).

But you better not name the alias find (findl, myfind etc), because it will become a habit and trouble for you if you try it on another system.

Upvotes: 6

Greg Hewgill
Greg Hewgill

Reputation: 994897

I would suggest that if you're writing scripts (which are more likely to be migrated from one system to another sometime in the future) that you should try to use the more specific form of the command, that is specifying the "." instead of relying on a default. For the same reason, I might even suggest writing sh scripts instead of relying on bash which might not be installed everywhere.

Upvotes: 3

James Fassett
James Fassett

Reputation: 41064

This is probably not what you want but how about: alias find="find ."

or choose a new name (findl for find local?)

Upvotes: 1

Related Questions