diff options
author | Junio C Hamano <gitster@pobox.com> | 2014-03-14 22:23:37 +0100 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2014-03-14 22:23:37 +0100 |
commit | dfcd354cdf38ff119c05e6e5f0e434bbc163ba41 (patch) | |
tree | af829295b55c89013ff1502b06a39476c35ce0cf /dir.c | |
parent | Merge branch 'jc/check-attr-honor-working-tree' (diff) | |
parent | t0008: skip trailing space test on Windows (diff) | |
download | git-dfcd354cdf38ff119c05e6e5f0e434bbc163ba41.tar.xz git-dfcd354cdf38ff119c05e6e5f0e434bbc163ba41.zip |
Merge branch 'nd/gitignore-trailing-whitespace'
Trailing whitespaces in .gitignore files, unless they are quoted for
fnmatch(3), e.g. "path\ ", are warned and ignored.
Strictly speaking, this is a backward incompatible change, but very
unlikely to bite any sane user and adjusting should be obvious and
easy.
* nd/gitignore-trailing-whitespace:
t0008: skip trailing space test on Windows
dir: ignore trailing spaces in exclude patterns
dir: warn about trailing spaces in exclude patterns
Diffstat (limited to 'dir.c')
-rw-r--r-- | dir.c | 20 |
1 files changed, 20 insertions, 0 deletions
@@ -503,6 +503,25 @@ void clear_exclude_list(struct exclude_list *el) el->filebuf = NULL; } +static void trim_trailing_spaces(char *buf) +{ + int i, last_space = -1, nr_spaces, len = strlen(buf); + for (i = 0; i < len; i++) + if (buf[i] == '\\') + i++; + else if (buf[i] == ' ') { + if (last_space == -1) { + last_space = i; + nr_spaces = 1; + } else + nr_spaces++; + } else + last_space = -1; + + if (last_space != -1 && last_space + nr_spaces == len) + buf[last_space] = '\0'; +} + int add_excludes_from_file_to_list(const char *fname, const char *base, int baselen, @@ -554,6 +573,7 @@ int add_excludes_from_file_to_list(const char *fname, if (buf[i] == '\n') { if (entry != buf + i && entry[0] != '#') { buf[i - (i && buf[i-1] == '\r')] = 0; + trim_trailing_spaces(entry); add_exclude(entry, base, baselen, el, lineno); } lineno++; |