]> git.ipfire.org Git - thirdparty/git.git/commitdiff
builtin/sparse-checkout: remove NEED_WORK_TREE flag
authorWilliam Sprent <williams@unity3d.com>
Mon, 27 Mar 2023 07:55:02 +0000 (07:55 +0000)
committerJunio C Hamano <gitster@pobox.com>
Mon, 27 Mar 2023 17:43:51 +0000 (10:43 -0700)
In preparation for adding a sub-command to 'sparse-checkout' that can be
run in a bare repository, remove the 'NEED_WORK_TREE' flag from its
entry in the 'commands' array of 'git.c'.

To avoid that this changes any behaviour, add calls to
'setup_work_tree()' to all of the 'sparse-checkout' sub-commands and add
tests that verify that 'sparse-checkout <cmd>' still fail with a clear
error message telling the user that the command needs a work tree.

Signed-off-by: William Sprent <williams@unity3d.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
builtin/sparse-checkout.c
git.c
t/t1091-sparse-checkout-builtin.sh

index 8d5ae6f2a60f913323cebf7014fd305ab09403bc..fe3d2686cea85417d8638bf2316731ea38e44ee5 100644 (file)
@@ -57,6 +57,7 @@ static int sparse_checkout_list(int argc, const char **argv, const char *prefix)
        char *sparse_filename;
        int res;
 
+       setup_work_tree();
        if (!core_apply_sparse_checkout)
                die(_("this worktree is not sparse"));
 
@@ -446,6 +447,7 @@ static int sparse_checkout_init(int argc, const char **argv, const char *prefix)
                OPT_END(),
        };
 
+       setup_work_tree();
        repo_read_index(the_repository);
 
        init_opts.cone_mode = -1;
@@ -758,6 +760,7 @@ static int sparse_checkout_add(int argc, const char **argv, const char *prefix)
                OPT_END(),
        };
 
+       setup_work_tree();
        if (!core_apply_sparse_checkout)
                die(_("no sparse-checkout to add to"));
 
@@ -804,6 +807,7 @@ static int sparse_checkout_set(int argc, const char **argv, const char *prefix)
                OPT_END(),
        };
 
+       setup_work_tree();
        repo_read_index(the_repository);
 
        set_opts.cone_mode = -1;
@@ -853,6 +857,7 @@ static int sparse_checkout_reapply(int argc, const char **argv,
                OPT_END(),
        };
 
+       setup_work_tree();
        if (!core_apply_sparse_checkout)
                die(_("must be in a sparse-checkout to reapply sparsity patterns"));
 
@@ -896,6 +901,7 @@ static int sparse_checkout_disable(int argc, const char **argv,
         * forcibly return to a dense checkout regardless of initial state.
         */
 
+       setup_work_tree();
        argc = parse_options(argc, argv, prefix,
                             builtin_sparse_checkout_disable_options,
                             builtin_sparse_checkout_disable_usage, 0);
diff --git a/git.c b/git.c
index ae2134f29a803f6ea4d68af9cba3c5ca3cfec325..9dee94a4b39bb84a8811a3475d51c59a2e7b6175 100644 (file)
--- a/git.c
+++ b/git.c
@@ -584,7 +584,7 @@ static struct cmd_struct commands[] = {
        { "show-branch", cmd_show_branch, RUN_SETUP },
        { "show-index", cmd_show_index, RUN_SETUP_GENTLY },
        { "show-ref", cmd_show_ref, RUN_SETUP },
-       { "sparse-checkout", cmd_sparse_checkout, RUN_SETUP | NEED_WORK_TREE },
+       { "sparse-checkout", cmd_sparse_checkout, RUN_SETUP },
        { "stage", cmd_add, RUN_SETUP | NEED_WORK_TREE },
        { "stash", cmd_stash, RUN_SETUP | NEED_WORK_TREE },
        { "status", cmd_status, RUN_SETUP | NEED_WORK_TREE },
index 627267be1531056c4eff9e5a0dc2bc1d8d1eab38..7216267aec73fffd1627a389ff018a01cee45600 100755 (executable)
@@ -882,4 +882,37 @@ test_expect_success 'by default, non-cone mode will warn on individual files' '
        grep "pass a leading slash before paths.*if you want a single file" warning
 '
 
+test_expect_success 'setup bare repo' '
+       git clone --bare "file://$(pwd)/repo" bare
+'
+test_expect_success 'list fails outside work tree' '
+       test_must_fail git -C bare sparse-checkout list 2>err &&
+       test_i18ngrep "this operation must be run in a work tree" err
+'
+
+test_expect_success 'add fails outside work tree' '
+       test_must_fail git -C bare sparse-checkout add deeper 2>err &&
+       test_i18ngrep "this operation must be run in a work tree" err
+'
+
+test_expect_success 'set fails outside work tree' '
+       test_must_fail git -C bare sparse-checkout set deeper 2>err &&
+       test_i18ngrep "this operation must be run in a work tree" err
+'
+
+test_expect_success 'init fails outside work tree' '
+       test_must_fail git -C bare sparse-checkout init 2>err &&
+       test_i18ngrep "this operation must be run in a work tree" err
+'
+
+test_expect_success 'reapply fails outside work tree' '
+       test_must_fail git -C bare sparse-checkout reapply 2>err &&
+       test_i18ngrep "this operation must be run in a work tree" err
+'
+
+test_expect_success 'disable fails outside work tree' '
+       test_must_fail git -C bare sparse-checkout disable 2>err &&
+       test_i18ngrep "this operation must be run in a work tree" err
+'
+
 test_done