git-grep: clarification on parameters.
We forgot to make sure that there is no more than one pattern parameter. Also when looking for files in a directory called '--others', it passed that path limiter without preceding the end-of-options marker '--' to underlying git-ls-files, which misunderstood it as one of its options instead. $ git grep --others -e Meta/Make Meta $ git grep -o -e Meta/Make Meta $ git grep -o Meta/Make Meta look for a string "Meta/Make" from untracked files in Meta/ directory. $ git grep Meta/Make --others looks for the same string from tracked files in ./--others directory. On the other hand, $ git grep -e Meta/Make --others does not have a freestanding pattern, so everybody is parameter and there is no path specifier. It looks for the string in all the untracked files without any path limiter. [jc: updated with usability enhancements and documentation cleanups from Sean.] Signed-off-by: Junio C Hamano <junkio@cox.net>maint
parent
0bdd79af62
commit
5b2bcc7b2d
|
@ -8,7 +8,7 @@ git-grep - print lines matching a pattern
|
||||||
|
|
||||||
SYNOPSIS
|
SYNOPSIS
|
||||||
--------
|
--------
|
||||||
'git-grep' [<option>...] <pattern> [<path>...]
|
'git-grep' [<option>...] [-e] <pattern> [--] [<path>...]
|
||||||
|
|
||||||
DESCRIPTION
|
DESCRIPTION
|
||||||
-----------
|
-----------
|
||||||
|
@ -18,13 +18,24 @@ containing a match to the given pattern.
|
||||||
|
|
||||||
OPTIONS
|
OPTIONS
|
||||||
-------
|
-------
|
||||||
|
`--`::
|
||||||
|
Signals the end of options; the rest of the parameters
|
||||||
|
are <path> limiters.
|
||||||
|
|
||||||
<option>...::
|
<option>...::
|
||||||
Either an option to pass to `grep` or `git-ls-files`.
|
Either an option to pass to `grep` or `git-ls-files`.
|
||||||
Some `grep` options, such as `-C` and `-m`, that take
|
|
||||||
parameters are known to `git-grep`.
|
The following are the specific `git-ls-files` options
|
||||||
|
that may be given: `-o`, `--cached`, `--deleted`, `--others`,
|
||||||
|
`--killed`, `--ignored`, `--modified`, `--exclude=*`,
|
||||||
|
`--exclude-from=*`, and `--exclude-per-directory=*`.
|
||||||
|
|
||||||
|
All other options will be passed to `grep`.
|
||||||
|
|
||||||
<pattern>::
|
<pattern>::
|
||||||
The pattern to look for.
|
The pattern to look for. The first non option is taken
|
||||||
|
as the pattern; if your pattern begins with a dash, use
|
||||||
|
`-e <pattern>`.
|
||||||
|
|
||||||
<path>...::
|
<path>...::
|
||||||
Optional paths to limit the set of files to be searched;
|
Optional paths to limit the set of files to be searched;
|
||||||
|
|
30
git-grep.sh
30
git-grep.sh
|
@ -3,22 +3,32 @@
|
||||||
# Copyright (c) Linus Torvalds, 2005
|
# Copyright (c) Linus Torvalds, 2005
|
||||||
#
|
#
|
||||||
|
|
||||||
USAGE='<option>... <pattern> <path>...'
|
USAGE='[<option>...] [-e] <pattern> [<path>...]'
|
||||||
SUBDIRECTORY_OK='Yes'
|
SUBDIRECTORY_OK='Yes'
|
||||||
. git-sh-setup
|
. git-sh-setup
|
||||||
|
|
||||||
|
got_pattern () {
|
||||||
|
if [ -z "$no_more_patterns" ]
|
||||||
|
then
|
||||||
|
pattern="$1" no_more_patterns=yes
|
||||||
|
else
|
||||||
|
die "git-grep: do not specify more than one pattern"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
no_more_patterns=
|
||||||
pattern=
|
pattern=
|
||||||
flags=()
|
flags=()
|
||||||
git_flags=()
|
git_flags=()
|
||||||
while : ; do
|
while : ; do
|
||||||
case "$1" in
|
case "$1" in
|
||||||
--cached|--deleted|--others|--killed|\
|
-o|--cached|--deleted|--others|--killed|\
|
||||||
--ignored|--exclude=*|\
|
--ignored|--modified|--exclude=*|\
|
||||||
--exclude-from=*|\--exclude-per-directory=*)
|
--exclude-from=*|\--exclude-per-directory=*)
|
||||||
git_flags=("${git_flags[@]}" "$1")
|
git_flags=("${git_flags[@]}" "$1")
|
||||||
;;
|
;;
|
||||||
-e)
|
-e)
|
||||||
pattern="$2"
|
got_pattern "$2"
|
||||||
shift
|
shift
|
||||||
;;
|
;;
|
||||||
-A|-B|-C|-D|-d|-f|-m)
|
-A|-B|-C|-D|-d|-f|-m)
|
||||||
|
@ -26,7 +36,7 @@ while : ; do
|
||||||
shift
|
shift
|
||||||
;;
|
;;
|
||||||
--)
|
--)
|
||||||
# The rest are git-ls-files paths (or flags)
|
# The rest are git-ls-files paths
|
||||||
shift
|
shift
|
||||||
break
|
break
|
||||||
;;
|
;;
|
||||||
|
@ -34,10 +44,12 @@ while : ; do
|
||||||
flags=("${flags[@]}" "$1")
|
flags=("${flags[@]}" "$1")
|
||||||
;;
|
;;
|
||||||
*)
|
*)
|
||||||
if [ -z "$pattern" ]; then
|
if [ -z "$no_more_patterns" ]
|
||||||
pattern="$1"
|
then
|
||||||
|
got_pattern "$1"
|
||||||
shift
|
shift
|
||||||
fi
|
fi
|
||||||
|
[ "$1" = -- ] && shift
|
||||||
break
|
break
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
@ -46,5 +58,5 @@ done
|
||||||
[ "$pattern" ] || {
|
[ "$pattern" ] || {
|
||||||
usage
|
usage
|
||||||
}
|
}
|
||||||
git-ls-files -z "${git_flags[@]}" "$@" |
|
git-ls-files -z "${git_flags[@]}" -- "$@" |
|
||||||
xargs -0 grep "${flags[@]}" -e "$pattern"
|
xargs -0 grep "${flags[@]}" -e "$pattern" --
|
||||||
|
|
Loading…
Reference in New Issue