completion: address sparse-checkout issues
commitfd6d9bec145924ba704b34f0788b239bff9d2898
authorLessley Dennington <lessleydennington@gmail.com>
Mon, 7 Feb 2022 17:31:43 +0000 (7 17:31 +0000)
committerJunio C Hamano <gitster@pobox.com>
Tue, 8 Feb 2022 18:15:42 +0000 (8 10:15 -0800)
treefe89eab9204c3b8ebbbfd1efd129a123a077946c
parent89bece5c8c96f0b962cfc89e63f82d603fd60bed
completion: address sparse-checkout issues

Correct multiple issues with tab completion of the git sparse-checkout
command. These issues were:

1. git sparse-checkout <TAB> previously resulted in an incomplete list of
subcommands (it was missing reapply and add).
2. Subcommand options were not tab-completable.
3. git sparse-checkout set <TAB> and git sparse-checkout add <TAB> showed
both file names and directory names. While this may be a less surprising
behavior for non-cone mode, cone mode sparse checkouts should complete
only directory names.

Note that while the new strategy of just using git ls-tree to complete on
directory names is simple and a step in the right direction, it does have
some caveats. These are:

1. Likelihood of poor performance in large monorepos (as a result of
recursively completing directory names).
2. Inability to handle paths containing unusual characters.

These caveats will be fixed by subsequent commits in this series.

Signed-off-by: Lessley Dennington <lessleydennington@gmail.com>
Reviewed-by: Elijah Newren <newren@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
contrib/completion/git-completion.bash
t/t9902-completion.sh