git-grep ignores untracked files

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Currently, git-grep ignores untracked files in the working directory.
For example:

    $ pattern=qazxswedc
    $ echo $pattern > foo
    $ git grep $pattern || echo not found
    not found

This is annoying and counter-intuitive, since it *does* search modified
files with unstaged changes.  More importantly, this is undocumented.

The situation is much worse when untracked files are given on the
command line.  For example, the following command warns me that a file
does not exist, as expected.

    $ git grep $pattern does_not_exist
    fatal: ambiguous argument 'does_not_exist': unknown revision or path not in the working tree.
    Use '--' to separate paths from revisions

However, if I give it an untracked file, it just tells me there's no match.

    $ git grep $pattern foo || echo not found
    not found

In this case, I would expect the program to either search that file
(would be nice!) or die with an error message (I'll take this for now).
Furthermore, when '--' is given, even the non-existent case fails
silently.

    $ git grep $pattern -- does_not_exist || echo not found
    not found

So, what I would I like to see?  Ideally, something like the following
series of patches:

1. Document the current behavior in the man page.

2. Issue a warning if any paths (pattern or non-pattern) fail to match
any files.  Ideally, this would work in all cases (work tree, --cached,
and trees).  If an untracked file matches a pattern that also matches
a tracked file, there would be no warning - not sure what's best in this
case.  This warning should probably be disable-able with a flag, say
--no-warn-if-unmatched.

3. If neither --cached nor trees are given, and a non-pattern filename
is given that does not not exist in the cache, search this file as well.
(That is, instead of issuing a warning, just search it.)  If the
filename is a directory, issue a warning.

4. Add an --untracked flag that causes grep to search *all* files in the
working directory, not just tracked ones.  (This includes searches with
and without a pathspec.)  The option would be incompatible with --cached
or given trees.


I post this wish list for several reasons.  First, to see if anyone
agrees with me.  Second, to see if this patch series has a chance of
ever being accepted.  Third, to implant this idea into someones head so
they write it for me :).  I may try to do it myself, but it will take me
a while.

To get started, here's a shot at #1.

Mark

---- 8< ----
>From 697d97ca45b5c7abe8c84c3caae28cf839c668ac Mon Sep 17 00:00:00 2001
From: Mark Lodato <lodatom@xxxxxxxxx>
Date: Sun, 14 Feb 2010 19:28:55 -0500
Subject: [PATCH] Documentation: clarify untracked files and <path>

Note that only tracked files are searched, that non-matching paths are
silently ignored, and that <path> is a glob(7) pattern.

Signed-off-by: Mark Lodato <lodatom@xxxxxxxxx>
---
 Documentation/git-grep.txt |    8 +++++++-
 1 files changed, 7 insertions(+), 1 deletions(-)

diff --git a/Documentation/git-grep.txt b/Documentation/git-grep.txt
index e019e76..fdc05ec 100644
--- a/Documentation/git-grep.txt
+++ b/Documentation/git-grep.txt
@@ -27,7 +27,9 @@ SYNOPSIS
 DESCRIPTION
 -----------
 Look for specified patterns in the working tree files, blobs
-registered in the index file, or given tree objects.
+registered in the index file, or given tree objects.  Only tracked files in
+the working tree are searched.  Paths that do not match are silently ignored,
+including paths to untracked files.
 
 
 OPTIONS
@@ -170,6 +172,10 @@ OPTIONS
 	Signals the end of options; the rest of the parameters
 	are <path> limiters.
 
+<path>...::
+	Only search files matching these wildcard patterns; see glob(7) for
+	the format.  If not given, all tracked files in the tree are searched.
+
 
 Example
 -------
-- 
1.7.0

--
To unsubscribe from this list: send the line "unsubscribe git" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Index of Archives]     [Linux Kernel Development]     [Gcc Help]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [V4L]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Fedora Users]