Skip to content

Commit

Permalink
git-check-attr: Normalize paths
Browse files Browse the repository at this point in the history
Normalize the path arguments (relative to the working tree root, if
applicable) before looking up their attributes.  This requires passing
the prefix down the call chain.

This fixes two test cases for different reasons:

* "unnormalized paths" is fixed because the .gitattribute-file-seeking
  code is not confused into reading the top-level file twice.

* "relative paths" is fixed because the canonical pathnames are passed
  to get_check_attr() or get_all_attrs(), allowing them to match the
  pathname patterns as expected.

Signed-off-by: Michael Haggerty <mhagger@alum.mit.edu>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
  • Loading branch information
Michael Haggerty authored and Junio C Hamano committed Aug 4, 2011
1 parent 0216af8 commit f5114a4
Show file tree
Hide file tree
Showing 2 changed files with 14 additions and 10 deletions.
20 changes: 12 additions & 8 deletions builtin/check-attr.c
Original file line number Diff line number Diff line change
Expand Up @@ -41,22 +41,26 @@ static void output_attr(int cnt, struct git_attr_check *check,
}
}

static void check_attr(int cnt, struct git_attr_check *check,
const char *file)
static void check_attr(const char *prefix, int cnt,
struct git_attr_check *check, const char *file)
{
char *full_path =
prefix_path(prefix, prefix ? strlen(prefix) : 0, file);
if (check != NULL) {
if (git_check_attr(file, cnt, check))
if (git_check_attr(full_path, cnt, check))
die("git_check_attr died");
output_attr(cnt, check, file);
} else {
if (git_all_attrs(file, &cnt, &check))
if (git_all_attrs(full_path, &cnt, &check))
die("git_all_attrs died");
output_attr(cnt, check, file);
free(check);
}
free(full_path);
}

static void check_attr_stdin_paths(int cnt, struct git_attr_check *check)
static void check_attr_stdin_paths(const char *prefix, int cnt,
struct git_attr_check *check)
{
struct strbuf buf, nbuf;
int line_termination = null_term_line ? 0 : '\n';
Expand All @@ -70,7 +74,7 @@ static void check_attr_stdin_paths(int cnt, struct git_attr_check *check)
die("line is badly quoted");
strbuf_swap(&buf, &nbuf);
}
check_attr(cnt, check, buf.buf);
check_attr(prefix, cnt, check, buf.buf);
maybe_flush_or_die(stdout, "attribute to stdout");
}
strbuf_release(&buf);
Expand Down Expand Up @@ -154,10 +158,10 @@ int cmd_check_attr(int argc, const char **argv, const char *prefix)
}

if (stdin_paths)
check_attr_stdin_paths(cnt, check);
check_attr_stdin_paths(prefix, cnt, check);
else {
for (i = filei; i < argc; i++)
check_attr(cnt, check, argv[i]);
check_attr(prefix, cnt, check, argv[i]);
maybe_flush_or_die(stdout, "attribute to stdout");
}
return 0;
Expand Down
4 changes: 2 additions & 2 deletions t/t0003-attributes.sh
Original file line number Diff line number Diff line change
Expand Up @@ -93,7 +93,7 @@ test_expect_success 'attribute test' '
'

test_expect_failure 'unnormalized paths' '
test_expect_success 'unnormalized paths' '
attr_check ./f f &&
attr_check ./a/g a/g &&
Expand All @@ -102,7 +102,7 @@ test_expect_failure 'unnormalized paths' '
'

test_expect_failure 'relative paths' '
test_expect_success 'relative paths' '
(cd a && attr_check ../f f) &&
(cd a && attr_check f f) &&
Expand Down

0 comments on commit f5114a4

Please sign in to comment.