gitignore.5: Clarify matching rules

Patterns containing a / are implicitly anchored to the directory
containing the relevant .gitignore file.

Patterns not containing a / are textual matches against the path
name relative to the directory containing .gitignore.

Signed-off-by: Jonathan Nieder <jrnieder@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Jonathan Nieder 2010-03-05 09:56:39 -06:00 committed by Junio C Hamano
parent 371276bf29
commit 81c13fde37

View File

@ -83,16 +83,20 @@ Patterns have the following format:
- If the pattern does not contain a slash '/', git treats it as - If the pattern does not contain a slash '/', git treats it as
a shell glob pattern and checks for a match against the a shell glob pattern and checks for a match against the
pathname without leading directories. pathname relative to the location of the `.gitignore` file
(relative to the toplevel of the work tree if not from a
`.gitignore` file).
- Otherwise, git treats the pattern as a shell glob suitable - Otherwise, git treats the pattern as a shell glob suitable
for consumption by fnmatch(3) with the FNM_PATHNAME flag: for consumption by fnmatch(3) with the FNM_PATHNAME flag:
wildcards in the pattern will not match a / in the pathname. wildcards in the pattern will not match a / in the pathname.
For example, "Documentation/\*.html" matches For example, "Documentation/\*.html" matches
"Documentation/git.html" but not "Documentation/git.html" but not "Documentation/ppc/ppc.html"
"Documentation/ppc/ppc.html". A leading slash matches the or "tools/perf/Documentation/perf.html".
beginning of the pathname; for example, "/*.c" matches
"cat-file.c" but not "mozilla-sha1/sha1.c". - A leading slash matches the beginning of the pathname.
For example, "/*.c" matches "cat-file.c" but not
"mozilla-sha1/sha1.c".
An example: An example: