Skip to content

Commit

Permalink
Merge branch 'dr/maint-ls-tree-prefix-recursion-fix'
Browse files Browse the repository at this point in the history
* dr/maint-ls-tree-prefix-recursion-fix:
  ls-tree $di $dir: do not mistakenly recurse into directories
  • Loading branch information
gitster committed Sep 15, 2010
2 parents 0c61c6d + b294ed6 commit 2e1e961
Show file tree
Hide file tree
Showing 2 changed files with 11 additions and 0 deletions.
2 changes: 2 additions & 0 deletions builtin/ls-tree.c
Original file line number Diff line number Diff line change
Expand Up @@ -52,6 +52,8 @@ static int show_recursive(const char *base, int baselen, const char *pathname)
speclen = strlen(spec);
if (speclen <= len)
continue;
if (spec[len] && spec[len] != '/')
continue;
if (memcmp(pathname, spec, len))
continue;
return 1;
Expand Down
9 changes: 9 additions & 0 deletions t/t3100-ls-tree-restrict.sh
Original file line number Diff line number Diff line change
Expand Up @@ -165,4 +165,13 @@ test_expect_success \
EOF
test_output'

test_expect_success \
'ls-tree with one path a prefix of the other' \
'git ls-tree $tree path2/baz path2/bazbo >current &&
make_expected <<\EOF &&
040000 tree X path2/baz
120000 blob X path2/bazbo
EOF
test_output'

test_done

0 comments on commit 2e1e961

Please sign in to comment.