sparse-checkout: use C-style quotes in 'list' subcommand

When in cone mode, the 'git sparse-checkout list' subcommand lists
the directories included in the sparse cone. When these directories
contain odd characters, such as a backslash, then we need to use
C-style quotes similar to 'git ls-tree'.

Signed-off-by: Derrick Stolee <dstolee@microsoft.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Derrick Stolee
2020-01-31 20:16:12 +00:00
committed by Junio C Hamano
parent bd64de42de
commit e55682ea26
2 changed files with 9 additions and 4 deletions

View File

@ -78,8 +78,10 @@ static int sparse_checkout_list(int argc, const char **argv)
string_list_sort(&sl); string_list_sort(&sl);
for (i = 0; i < sl.nr; i++) for (i = 0; i < sl.nr; i++) {
printf("%s\n", sl.items[i].string); quote_c_style(sl.items[i].string, NULL, stdout, 0);
printf("\n");
}
return 0; return 0;
} }

View File

@ -406,7 +406,8 @@ test_expect_success BSLASHPSPEC 'pattern-checks: escaped "*"' '
EOF EOF
test_cmp expect escaped/.git/info/sparse-checkout && test_cmp expect escaped/.git/info/sparse-checkout &&
check_read_tree_errors escaped "a zbad\\dir zdoes*exist" && check_read_tree_errors escaped "a zbad\\dir zdoes*exist" &&
git -C escaped ls-tree -d --name-only HEAD | git -C escaped sparse-checkout set --stdin && git -C escaped ls-tree -d --name-only HEAD >list-expect &&
git -C escaped sparse-checkout set --stdin <list-expect &&
cat >expect <<-\EOF && cat >expect <<-\EOF &&
/* /*
!/*/ !/*/
@ -417,7 +418,9 @@ test_expect_success BSLASHPSPEC 'pattern-checks: escaped "*"' '
/zdoes\*exist/ /zdoes\*exist/
EOF EOF
test_cmp expect escaped/.git/info/sparse-checkout && test_cmp expect escaped/.git/info/sparse-checkout &&
check_files escaped "a deep folder1 folder2 zbad\\dir zdoes*exist" check_files escaped "a deep folder1 folder2 zbad\\dir zdoes*exist" &&
git -C escaped sparse-checkout list >list-actual &&
test_cmp list-expect list-actual
' '
test_done test_done