Merge branch 'dr/maint-ls-tree-prefix-recursion-fix'

* dr/maint-ls-tree-prefix-recursion-fix:
  ls-tree $di $dir: do not mistakenly recurse into directories
This commit is contained in:
Junio C Hamano 2010-09-15 12:41:13 -07:00
Родитель 0c61c6de34 b294ed637d
Коммит 2e1e96126f
2 изменённых файлов: 11 добавлений и 0 удалений

Просмотреть файл

@ -52,6 +52,8 @@ static int show_recursive(const char *base, int baselen, const char *pathname)
speclen = strlen(spec); speclen = strlen(spec);
if (speclen <= len) if (speclen <= len)
continue; continue;
if (spec[len] && spec[len] != '/')
continue;
if (memcmp(pathname, spec, len)) if (memcmp(pathname, spec, len))
continue; continue;
return 1; return 1;

Просмотреть файл

@ -165,4 +165,13 @@ test_expect_success \
EOF EOF
test_output' 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 test_done