From: "Lessley Dennington via GitGitGadget" <gitgitgadget@gmail.com> To: git@vger.kernel.org Cc: stolee@gmail.com, gitster@pobox.com, johannes.schindelin@gmail.com, "Elijah Newren" <newren@gmail.com>, "Taylor Blau" <me@ttaylorr.com>, "SZEDER Gábor" <szeder.dev@gmail.com>, "Lessley Dennington" <lessleydennington@gmail.com> Subject: [PATCH v4 0/3] completion: sparse-checkout updates Date: Thu, 27 Jan 2022 21:21:51 +0000 [thread overview] Message-ID: <pull.1108.v4.git.1643318514.gitgitgadget@gmail.com> (raw) In-Reply-To: <pull.1108.v3.git.1641841193.gitgitgadget@gmail.com> This series is based on en/sparse-checkout-set. It updates custom tab completion for the sparse-checkout command. Specifically, it corrects the following issues with the current method: 1. git sparse-checkout <TAB> results in an incomplete list of subcommands (it is missing reapply and add). 2. Options for subcommands are not tab-completable. 3. git sparse-checkout set <TAB> and git sparse-checkout add <TAB> show both file names and directory names. While this is the desired behavior for non-cone mode, we want to only show directories in cone mode. The first commit in this series is a set of tests that highlight each of the above issues. The next commit updates the _git_sparse_checkout method in git-completion.bash to enable previously-failing tests to pass. The final commit modifies the original implementation (which recursively printed prospective directories for completion) to only print directories at the current level for improved performance. Changes since V3 ================ * Update commit descriptions to begin with completion instead of sparse-checkout. * Remove explicit completion of --help, as this is inconsistent with the rest of the completion script. * Use __gitcomp_builtin to auto-complete subcommand options (and remove option completion test from previous iterations, as it is no longer necessary). * Use __git_complete_index_file helper function in place of __gitcomp "$(git ls-tree -d -r HEAD --name-only). * If in cone-mode sparse checkout, only show directory completions. If in non-cone mode sparse checkout show both files and directories. Changes since V2 ================ * Change use of $prev to $subcommand in _git_sparse_checkout() method in git-completion.bash. * State explicitly that directory completion applies in both cone and non-cone mode in 'sparse-checkout: custom tab completion' commit * Add new patch with __gitcomp_directories method to improve performance by only outputting directories at the current level. Changes since V1 ================ * Rebase onto en/sparse-checkout-set. * Add subcommand options (including --no-cone) for set and reapply. * Extend 'sparse-checkout completes subcommand options' test to validate new set/reapply subcommand options. * No longer set index.sparse to false in 'sparse-checkout completes directory names' test. Thanks, Lessley Lessley Dennington (3): completion: add sparse-checkout tests completion: sparse-checkout updates completion: ensure cone mode completion with multiple <TAB>s contrib/completion/git-completion.bash | 44 ++++++++++++--- t/t9902-completion.sh | 75 ++++++++++++++++++++++++++ 2 files changed, 112 insertions(+), 7 deletions(-) base-commit: dfac9b609f86cd4f6ce896df9e1172d2a02cde48 Published-As: https://github.com/gitgitgadget/git/releases/tag/pr-1108%2Fldennington%2Fsparse-checkout-bash-completion-v4 Fetch-It-Via: git fetch https://github.com/gitgitgadget/git pr-1108/ldennington/sparse-checkout-bash-completion-v4 Pull-Request: https://github.com/gitgitgadget/git/pull/1108 Range-diff vs v3: 1: bbc2d21e1d1 ! 1: 5bb598a055d sparse-checkout: custom tab completion tests @@ Metadata Author: Lessley Dennington <lessleydennington@gmail.com> ## Commit message ## - sparse-checkout: custom tab completion tests + completion: add sparse-checkout tests - Add tests for missing/incorrect components of custom tab completion for the - sparse-checkout command. These tests specifically highlight the following: + Add tests for missing/incorrect components of custom tab completion for + the sparse-checkout command. These tests specifically highlight the + following: 1. git sparse-checkout <TAB> results in an incomplete list of subcommands (it is missing reapply and add). - 2. git sparse-checkout --<TAB> does not complete the help option. - 3. Options for subcommands are not tab-completable. - 4. git sparse-checkout set <TAB> and git sparse-checkout add <TAB> show - both file names and directory names. + 2. git sparse-checkout set <TAB> and git sparse-checkout add <TAB> show + both file names and directory names. While this is the correct behavior + for non-cone mode, cone mode sparse checkouts should complete only + directory names. - Although these tests currently fail, they will succeed with the - sparse-checkout modifications in git-completion.bash in the next commit in - this series. + Although the first two of these tests currently fail, they will succeed + with the sparse-checkout modifications in git-completion.bash in the next + commit in this series. Signed-off-by: Lessley Dennington <lessleydennington@gmail.com> @@ t/t9902-completion.sh: test_expect_success 'git checkout - with --detach, comple + EOF +' + -+test_expect_failure 'sparse-checkout completes options' ' -+ test_completion "git sparse-checkout --" <<-\EOF -+ --help Z -+ EOF -+' -+ -+test_expect_failure 'sparse-checkout completes subcommand options' ' -+ test_completion "git sparse-checkout init --" <<-\EOF && -+ --cone Z -+ --no-cone Z -+ --sparse-index Z -+ --no-sparse-index Z -+ EOF -+ -+ test_completion "git sparse-checkout set --" <<-\EOF && -+ --cone Z -+ --no-cone Z -+ --sparse-index Z -+ --no-sparse-index Z -+ --stdin Z -+ EOF -+ -+ test_completion "git sparse-checkout reapply --" <<-\EOF && -+ --cone Z -+ --no-cone Z -+ --sparse-index Z -+ --no-sparse-index Z -+ EOF -+ -+ test_completion "git sparse-checkout add --" <<-\EOF -+ --stdin Z -+ EOF -+' -+ -+test_expect_failure 'sparse-checkout completes directory names' ' ++test_expect_failure 'cone mode sparse-checkout completes directory names' ' + # set up sparse-checkout repo + git init sparse-checkout && + ( @@ t/t9902-completion.sh: test_expect_success 'git checkout - with --detach, comple + ) && + + # initialize sparse-checkout definitions -+ git -C sparse-checkout sparse-checkout init --cone && -+ git -C sparse-checkout sparse-checkout set folder1/0 folder3 && ++ git -C sparse-checkout sparse-checkout set --cone folder1/0 folder3 && + + # test tab completion + ( + cd sparse-checkout && + test_completion "git sparse-checkout set f" <<-\EOF -+ folder1 Z -+ folder1/0 Z -+ folder1/0/1 Z -+ folder2 Z -+ folder2/0 Z -+ folder3 Z ++ folder1 ++ folder2 ++ folder3 ++ EOF ++ ) && ++ ++ ( ++ cd sparse-checkout && ++ test_completion "git sparse-checkout set folder1/" <<-\EOF ++ folder1/0 ++ EOF ++ ) && ++ ++ ( ++ cd sparse-checkout && ++ test_completion "git sparse-checkout set folder1/0/" <<-\EOF ++ folder1/0/1 + EOF + ) && + + ( + cd sparse-checkout/folder1 && -+ test_completion "git sparse-checkout add " <<-\EOF -+ ./ Z -+ 0 Z -+ 0/1 Z ++ test_completion "git sparse-checkout add 0" <<-\EOF ++ 0 ++ EOF ++ ) ++' ++ ++test_expect_success 'non-cone mode sparse-checkout uses bash completion' ' ++ # reset sparse-checkout repo to non-cone mode ++ git -C sparse-checkout sparse-checkout disable && ++ git -C sparse-checkout sparse-checkout set && ++ ++ # test tab completion ++ ( ++ cd sparse-checkout && ++ # expected to be empty since we have not configured ++ # custom completion for non-cone mode ++ test_completion "git sparse-checkout set f" <<-\EOF ++ + EOF + ) +' 2: 256e5f034c6 ! 2: 7d70beb2a6b sparse-checkout: custom tab completion @@ Metadata Author: Lessley Dennington <lessleydennington@gmail.com> ## Commit message ## - sparse-checkout: custom tab completion + completion: sparse-checkout updates - Fix custom tab completion for sparse-checkout command. This will ensure: + Fix custom tab completion for the sparse-checkout command. This will + ensure: 1. The full list of subcommands is provided when users enter git sparse-checkout <TAB>. - 2. The --help option is tab-completable. - 3. Subcommand options are tab-completable. - 4. A list of directories (but not files) is provided when users enter git - sparse-checkout add <TAB> or git sparse-checkout set <TAB>. It is - important to note that this will apply for both cone mode and non-cone - mode (even though non-cone mode matches on patterns rather than - directories). + 2. Subcommand options are tab-completable. + 3. A list of directories (but not files) is provided when users enter git + sparse-checkout add <TAB> or git sparse-checkout set <TAB> in cone mode + only. In non-cone mode, these commands will continue to complete both + directory and file names. Failing tests that were added in the previous commit to verify these scenarios are now passing with these updates. @@ Commit message ## contrib/completion/git-completion.bash ## @@ contrib/completion/git-completion.bash: _git_show_branch () - __git_complete_revlist - } -+__git_sparse_checkout_subcommand_opts="--cone --no-cone --sparse-index --no-sparse-index" -+ _git_sparse_checkout () { - local subcommands="list init set disable" @@ contrib/completion/git-completion.bash: _git_show_branch () local subcommand="$(__git_find_on_cmdline "$subcommands")" + if [ -z "$subcommand" ]; then -- __gitcomp "$subcommands" -- return -+ case "$cur" in -+ --*) -+ __gitcomp "--help" -+ ;; -+ *) -+ __gitcomp "$subcommands" -+ ;; -+ esac + __gitcomp "$subcommands" + return fi -- case "$subcommand,$cur" in + case "$subcommand,$cur" in - init,--*) - __gitcomp "--cone" - ;; - set,--*) - __gitcomp "--stdin" -- ;; ++ *,--*) ++ __gitcomp_builtin sparse-checkout_$subcommand "" "--" + ;; - *) -- ;; -+ case "$subcommand" in -+ set) -+ __gitcomp "$__git_sparse_checkout_subcommand_opts --stdin" -+ __gitcomp "$(git ls-tree -d -r HEAD --name-only)" -+ ;; -+ add) -+ __gitcomp "--stdin" -+ __gitcomp "$(git ls-tree -d -r HEAD --name-only)" -+ ;; -+ init|reapply) -+ __gitcomp "$__git_sparse_checkout_subcommand_opts" -+ ;; -+ *) -+ ;; ++ set,*|add,*) ++ if [ $(__git config core.sparseCheckoutCone) ]; then ++ __git_complete_index_file "--directory" ++ fi + ;; esac } - ## t/t9902-completion.sh ## @@ t/t9902-completion.sh: test_expect_success 'git checkout - with --detach, complete only references' ' @@ t/t9902-completion.sh: test_expect_failure 'sparse-checkout completes subcommand EOF ' --test_expect_failure 'sparse-checkout completes options' ' -+test_expect_success 'sparse-checkout completes options' ' - test_completion "git sparse-checkout --" <<-\EOF - --help Z - EOF - ' - --test_expect_failure 'sparse-checkout completes subcommand options' ' -+test_expect_success 'sparse-checkout completes subcommand options' ' - test_completion "git sparse-checkout init --" <<-\EOF && - --cone Z - --no-cone Z -@@ t/t9902-completion.sh: test_expect_failure 'sparse-checkout completes subcommand options' ' - EOF - ' - --test_expect_failure 'sparse-checkout completes directory names' ' -+test_expect_success 'sparse-checkout completes directory names' ' +-test_expect_failure 'cone mode sparse-checkout completes directory names' ' ++test_expect_success 'cone mode sparse-checkout completes directory names' ' # set up sparse-checkout repo git init sparse-checkout && ( 3: aa9ea67180d ! 3: 760cae85bd4 sparse-checkout: limit tab completion to a single level @@ Metadata Author: Lessley Dennington <lessleydennington@gmail.com> ## Commit message ## - sparse-checkout: limit tab completion to a single level + completion: ensure cone mode completion with multiple <TAB>s - Ensure only directories at the current level will be tab-completed with - the sparse-checkout command. For example, if paths a/b/c/ and a/d/ exist - in the current directory, running a/<TAB> will result in: + Ensure users in a cone mode sparse checkout can tab-complete to + directories at multiple levels with multiple <TAB>s. For example, if path + a/b/c/ exists in the current directory, running a<TAB>b<TAB> will result + in: - a/b/ - a/d/ + a/b/c/ The 'sparse-checkout completes directory names' test has also been - updated/extended according to these changes. + updated with trailing slashes according to these changes. Co-authored-by: Elijah Newren <newren@gmail.com> Co-authored-by: Lessley Dennington <lessleydennington@gmail.com> @@ contrib/completion/git-completion.bash: _git_show_branch () + fi +} + - __git_sparse_checkout_subcommand_opts="--cone --no-cone --sparse-index --no-sparse-index" - _git_sparse_checkout () + { + local subcommands="list init set disable add reapply" + local subcommand="$(__git_find_on_cmdline "$subcommands")" +- + if [ -z "$subcommand" ]; then + __gitcomp "$subcommands" + return @@ contrib/completion/git-completion.bash: _git_sparse_checkout () - case "$subcommand" in - set) - __gitcomp "$__git_sparse_checkout_subcommand_opts --stdin" -- __gitcomp "$(git ls-tree -d -r HEAD --name-only)" -+ __gitcomp_directories - ;; - add) - __gitcomp "--stdin" -- __gitcomp "$(git ls-tree -d -r HEAD --name-only)" -+ __gitcomp_directories - ;; - init|reapply) - __gitcomp "$__git_sparse_checkout_subcommand_opts" + ;; + set,*|add,*) + if [ $(__git config core.sparseCheckoutCone) ]; then +- __git_complete_index_file "--directory" ++ __gitcomp_directories + fi + ;; + esac ## t/t9902-completion.sh ## -@@ t/t9902-completion.sh: test_expect_success 'sparse-checkout completes directory names' ' +@@ t/t9902-completion.sh: test_expect_success 'cone mode sparse-checkout completes directory names' ' ( cd sparse-checkout && test_completion "git sparse-checkout set f" <<-\EOF -- folder1 Z -- folder1/0 Z -- folder1/0/1 Z -- folder2 Z -- folder2/0 Z -- folder3 Z +- folder1 +- folder2 +- folder3 + folder1/ + folder2/ + folder3/ -+ EOF -+ ) && -+ -+ ( -+ cd sparse-checkout && -+ test_completion "git sparse-checkout set folder1/" <<-\EOF + EOF + ) && + + ( + cd sparse-checkout && + test_completion "git sparse-checkout set folder1/" <<-\EOF +- folder1/0 + folder1/0/ -+ EOF -+ ) && -+ -+ ( -+ cd sparse-checkout && -+ test_completion "git sparse-checkout set folder1/0/" <<-\EOF + EOF + ) && + + ( + cd sparse-checkout && + test_completion "git sparse-checkout set folder1/0/" <<-\EOF +- folder1/0/1 + folder1/0/1/ EOF ) && ( cd sparse-checkout/folder1 && -- test_completion "git sparse-checkout add " <<-\EOF -- ./ Z -- 0 Z -- 0/1 Z -+ test_completion "git sparse-checkout add 0" <<-\EOF + test_completion "git sparse-checkout add 0" <<-\EOF +- 0 + 0/ EOF ) -- gitgitgadget
next prev parent reply other threads:[~2022-01-27 21:21 UTC|newest] Thread overview: 95+ messages / expand[flat|nested] mbox.gz Atom feed top 2021-12-30 0:32 [PATCH 0/2] sparse checkout: custom bash completion updates Lessley Dennington via GitGitGadget 2021-12-30 0:32 ` [PATCH 1/2] sparse-checkout: custom tab completion tests Lessley Dennington via GitGitGadget 2021-12-30 13:43 ` Derrick Stolee 2021-12-30 16:19 ` Lessley Dennington 2021-12-30 17:43 ` Derrick Stolee 2021-12-31 19:27 ` Elijah Newren 2022-01-04 19:19 ` Lessley Dennington 2021-12-30 0:32 ` [PATCH 2/2] sparse-checkout: custom tab completion Lessley Dennington via GitGitGadget 2021-12-30 13:50 ` Derrick Stolee 2021-12-30 16:24 ` Lessley Dennington 2021-12-30 19:26 ` [PATCH v2 0/2] sparse checkout: custom bash completion updates Lessley Dennington via GitGitGadget 2021-12-30 19:26 ` [PATCH v2 1/2] sparse-checkout: custom tab completion tests Lessley Dennington via GitGitGadget 2021-12-31 20:03 ` Elijah Newren 2021-12-31 22:20 ` Junio C Hamano 2021-12-31 22:25 ` Elijah Newren 2022-01-04 19:25 ` Lessley Dennington 2022-01-04 20:25 ` Elijah Newren 2022-01-05 14:05 ` Lessley Dennington 2022-01-04 19:24 ` Lessley Dennington 2021-12-30 19:26 ` [PATCH v2 2/2] sparse-checkout: custom tab completion Lessley Dennington via GitGitGadget 2021-12-31 22:52 ` Elijah Newren 2022-01-04 19:41 ` Lessley Dennington 2022-01-04 20:42 ` Elijah Newren 2022-01-05 20:20 ` Lessley Dennington 2022-01-05 22:55 ` Elijah Newren 2022-01-10 18:59 ` [PATCH v3 0/3] sparse checkout: custom bash completion updates Lessley Dennington via GitGitGadget 2022-01-10 18:59 ` [PATCH v3 1/3] sparse-checkout: custom tab completion tests Lessley Dennington via GitGitGadget 2022-01-10 18:59 ` [PATCH v3 2/3] sparse-checkout: custom tab completion Lessley Dennington via GitGitGadget 2022-01-15 9:57 ` SZEDER Gábor 2022-01-16 1:03 ` Elijah Newren 2022-01-16 22:13 ` Junio C Hamano 2022-01-17 18:14 ` Elijah Newren 2022-01-17 19:40 ` Junio C Hamano 2022-01-18 17:56 ` Lessley Dennington 2022-01-22 1:07 ` Lessley Dennington 2022-01-22 1:08 ` Lessley Dennington 2022-01-22 2:11 ` Lessley Dennington 2022-01-18 21:02 ` SZEDER Gábor 2022-01-18 21:43 ` Elijah Newren 2022-01-18 17:59 ` Lessley Dennington 2022-01-18 22:22 ` SZEDER Gábor 2022-01-18 23:30 ` Elijah Newren 2022-01-10 18:59 ` [PATCH v3 3/3] sparse-checkout: limit tab completion to a single level Lessley Dennington via GitGitGadget 2022-01-12 23:43 ` Lessley Dennington 2022-01-13 0:00 ` Junio C Hamano 2022-01-13 0:38 ` Elijah Newren 2022-01-13 19:02 ` Lessley Dennington 2022-01-10 20:38 ` [PATCH v3 0/3] sparse checkout: custom bash completion updates Elijah Newren 2022-01-11 17:17 ` Lessley Dennington 2022-01-11 19:45 ` Taylor Blau 2022-01-12 18:35 ` Lessley Dennington 2022-01-27 21:21 ` Lessley Dennington via GitGitGadget [this message] 2022-01-27 21:21 ` [PATCH v4 1/3] completion: add sparse-checkout tests Lessley Dennington via GitGitGadget 2022-01-28 0:08 ` Elijah Newren 2022-01-28 1:56 ` Junio C Hamano 2022-01-28 2:04 ` Elijah Newren 2022-01-27 21:21 ` [PATCH v4 2/3] completion: sparse-checkout updates Lessley Dennington via GitGitGadget 2022-01-28 1:21 ` Elijah Newren 2022-01-31 20:03 ` Lessley Dennington 2022-01-31 21:37 ` Elijah Newren 2022-01-27 21:21 ` [PATCH v4 3/3] completion: ensure cone mode completion with multiple <TAB>s Lessley Dennington via GitGitGadget 2022-01-28 1:53 ` Elijah Newren 2022-02-03 20:44 ` [PATCH v5 0/3] completion: sparse-checkout updates Lessley Dennington via GitGitGadget 2022-02-03 20:44 ` [PATCH v5 1/3] completion: address sparse-checkout issues Lessley Dennington via GitGitGadget 2022-02-03 23:52 ` Elijah Newren 2022-02-04 0:34 ` Lessley Dennington 2022-02-03 20:44 ` [PATCH v5 2/3] completion: improve sparse-checkout cone mode directory completion Lessley Dennington via GitGitGadget 2022-02-03 20:44 ` [PATCH v5 3/3] completion: handle unusual characters for sparse-checkout Lessley Dennington via GitGitGadget 2022-02-03 23:58 ` Elijah Newren 2022-02-04 0:37 ` Lessley Dennington 2022-02-04 4:25 ` Ævar Arnfjörð Bjarmason 2022-02-04 21:55 ` Junio C Hamano 2022-02-03 21:48 ` [PATCH v5 0/3] completion: sparse-checkout updates Junio C Hamano 2022-02-03 22:17 ` Lessley Dennington 2022-02-03 23:28 ` Junio C Hamano 2022-02-03 23:59 ` Lessley Dennington 2022-02-04 2:43 ` Lessley Dennington 2022-02-04 3:28 ` Lessley Dennington 2022-02-04 4:21 ` Ævar Arnfjörð Bjarmason 2022-02-04 3:26 ` [PATCH v6 " Lessley Dennington via GitGitGadget 2022-02-04 3:26 ` [PATCH v6 1/3] completion: address sparse-checkout issues Lessley Dennington via GitGitGadget 2022-02-04 3:26 ` [PATCH v6 2/3] completion: improve sparse-checkout cone mode directory completion Lessley Dennington via GitGitGadget 2022-02-04 3:26 ` [PATCH v6 3/3] completion: handle unusual characters for sparse-checkout Lessley Dennington via GitGitGadget 2022-02-04 6:05 ` [PATCH v6 0/3] completion: sparse-checkout updates Elijah Newren 2022-02-04 17:04 ` Junio C Hamano 2022-02-04 17:55 ` Elijah Newren 2022-02-04 19:54 ` Junio C Hamano 2022-02-04 20:01 ` Elijah Newren 2022-02-04 21:47 ` Junio C Hamano 2022-02-07 17:31 ` [PATCH v7 " Lessley Dennington via GitGitGadget 2022-02-07 17:31 ` [PATCH v7 1/3] completion: address sparse-checkout issues Lessley Dennington via GitGitGadget 2022-02-07 17:31 ` [PATCH v7 2/3] completion: improve sparse-checkout cone mode directory completion Lessley Dennington via GitGitGadget 2022-02-07 17:31 ` [PATCH v7 3/3] completion: handle unusual characters for sparse-checkout Lessley Dennington via GitGitGadget 2022-04-06 9:42 ` Adam Dinwoodie 2022-02-08 4:16 ` [PATCH v7 0/3] completion: sparse-checkout updates Elijah Newren
Reply instructions: You may reply publicly to this message via plain-text email using any one of the following methods: * Save the following mbox file, import it into your mail client, and reply-to-all from there: mbox Avoid top-posting and favor interleaved quoting: https://en.wikipedia.org/wiki/Posting_style#Interleaved_style List information: http://vger.kernel.org/majordomo-info.html * Reply using the --to, --cc, and --in-reply-to switches of git-send-email(1): git send-email \ --in-reply-to=pull.1108.v4.git.1643318514.gitgitgadget@gmail.com \ --to=gitgitgadget@gmail.com \ --cc=git@vger.kernel.org \ --cc=gitster@pobox.com \ --cc=johannes.schindelin@gmail.com \ --cc=lessleydennington@gmail.com \ --cc=me@ttaylorr.com \ --cc=newren@gmail.com \ --cc=stolee@gmail.com \ --cc=szeder.dev@gmail.com \ --subject='Re: [PATCH v4 0/3] completion: sparse-checkout updates' \ /path/to/YOUR_REPLY https://kernel.org/pub/software/scm/git/docs/git-send-email.html * If your mail client supports setting the In-Reply-To header via mailto: links, try the mailto: link
Code repositories for project(s) associated with this inbox: https://80x24.org/mirrors/git.git This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).