I've long been confused by something in the man page for gitignore. I think 
it's unclear and I'd like to propose a change. The passage is this (source at 
https://git.kernel.org/pub/scm/git/git-manpages.git/tree/man5/gitignore.5):

Two consecutive asterisks ("**") in patterns matched against full
pathname may have special meaning:

o   A leading "**" followed by a slash means match in all directories.
    For example, "**/foo" matches file or directory "foo" anywhere, the
    same as pattern "foo". "**/foo/bar" matches file or directory "bar"
    anywhere that is directly under directory "foo".

...

In the first paragraph, it would be clearer to specify:

Two consecutive asterisks ("**"), in patterns matched against a full
pathname, are a wildcard representing some arbitrary number of nested
directories within that pathname:

In the second paragraph, I suggest removing the first pattern, "**/foo", since it is completely 
redundant. There are no circumstances when "**/foo" is necessary in place of plain "foo", 
and its presence muddies discussion.

Leading "**" may represent nested directories in a pathname, but is useful only 
before a _pattern_ containing nested directories. I suggest making that explicit. Here is 
how I propose to rewrite it:

o   A leading "**", followed by a slash and a pattern containing nested
    directories, means match that pattern in all pathnames.
    For example, "**/foo/bar" matches file or directory "bar"
    anywhere that is directly under directory "foo". It would match
    "foo/bar", "other/foo/bar", "src/foo/bar/scram/gravy".

Thanks.

- dpb

Reply via email to