Merge branch 'mt/quiet-with-delayed-checkout' into maint
The delayed checkout code path in "git checkout" etc. were chatty even when --quiet and/or --no-progress options were given. * mt/quiet-with-delayed-checkout: checkout: make delayed checkout respect --quiet and --no-progress
This commit is contained in:
commit
cd9a57f6a0
@ -404,7 +404,7 @@ static int checkout_worktree(const struct checkout_opts *opts,
|
|||||||
mem_pool_discard(&ce_mem_pool, should_validate_cache_entries());
|
mem_pool_discard(&ce_mem_pool, should_validate_cache_entries());
|
||||||
remove_marked_cache_entries(&the_index, 1);
|
remove_marked_cache_entries(&the_index, 1);
|
||||||
remove_scheduled_dirs();
|
remove_scheduled_dirs();
|
||||||
errs |= finish_delayed_checkout(&state, &nr_checkouts);
|
errs |= finish_delayed_checkout(&state, &nr_checkouts, opts->show_progress);
|
||||||
|
|
||||||
if (opts->count_checkout_paths) {
|
if (opts->count_checkout_paths) {
|
||||||
if (nr_unmerged)
|
if (nr_unmerged)
|
||||||
|
7
entry.c
7
entry.c
@ -159,7 +159,8 @@ static int remove_available_paths(struct string_list_item *item, void *cb_data)
|
|||||||
return !available;
|
return !available;
|
||||||
}
|
}
|
||||||
|
|
||||||
int finish_delayed_checkout(struct checkout *state, int *nr_checkouts)
|
int finish_delayed_checkout(struct checkout *state, int *nr_checkouts,
|
||||||
|
int show_progress)
|
||||||
{
|
{
|
||||||
int errs = 0;
|
int errs = 0;
|
||||||
unsigned delayed_object_count;
|
unsigned delayed_object_count;
|
||||||
@ -173,7 +174,9 @@ int finish_delayed_checkout(struct checkout *state, int *nr_checkouts)
|
|||||||
|
|
||||||
dco->state = CE_RETRY;
|
dco->state = CE_RETRY;
|
||||||
delayed_object_count = dco->paths.nr;
|
delayed_object_count = dco->paths.nr;
|
||||||
progress = start_delayed_progress(_("Filtering content"), delayed_object_count);
|
progress = show_progress
|
||||||
|
? start_delayed_progress(_("Filtering content"), delayed_object_count)
|
||||||
|
: NULL;
|
||||||
while (dco->filters.nr > 0) {
|
while (dco->filters.nr > 0) {
|
||||||
for_each_string_list_item(filter, &dco->filters) {
|
for_each_string_list_item(filter, &dco->filters) {
|
||||||
struct string_list available_paths = STRING_LIST_INIT_NODUP;
|
struct string_list available_paths = STRING_LIST_INIT_NODUP;
|
||||||
|
3
entry.h
3
entry.h
@ -43,7 +43,8 @@ static inline int checkout_entry(struct cache_entry *ce,
|
|||||||
}
|
}
|
||||||
|
|
||||||
void enable_delayed_checkout(struct checkout *state);
|
void enable_delayed_checkout(struct checkout *state);
|
||||||
int finish_delayed_checkout(struct checkout *state, int *nr_checkouts);
|
int finish_delayed_checkout(struct checkout *state, int *nr_checkouts,
|
||||||
|
int show_progress);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Unlink the last component and schedule the leading directories for
|
* Unlink the last component and schedule the leading directories for
|
||||||
|
@ -6,6 +6,7 @@ GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME=main
|
|||||||
export GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME
|
export GIT_TEST_DEFAULT_INITIAL_BRANCH_NAME
|
||||||
|
|
||||||
. ./test-lib.sh
|
. ./test-lib.sh
|
||||||
|
. "$TEST_DIRECTORY"/lib-terminal.sh
|
||||||
|
|
||||||
TEST_ROOT="$PWD"
|
TEST_ROOT="$PWD"
|
||||||
PATH=$TEST_ROOT:$PATH
|
PATH=$TEST_ROOT:$PATH
|
||||||
@ -1061,4 +1062,74 @@ test_expect_success PERL,SYMLINKS,CASE_INSENSITIVE_FS \
|
|||||||
)
|
)
|
||||||
'
|
'
|
||||||
|
|
||||||
|
test_expect_success PERL 'setup for progress tests' '
|
||||||
|
git init progress &&
|
||||||
|
(
|
||||||
|
cd progress &&
|
||||||
|
git config filter.delay.process "rot13-filter.pl delay-progress.log clean smudge delay" &&
|
||||||
|
git config filter.delay.required true &&
|
||||||
|
|
||||||
|
echo "*.a filter=delay" >.gitattributes &&
|
||||||
|
touch test-delay10.a &&
|
||||||
|
git add . &&
|
||||||
|
git commit -m files
|
||||||
|
)
|
||||||
|
'
|
||||||
|
|
||||||
|
test_delayed_checkout_progress () {
|
||||||
|
if test "$1" = "!"
|
||||||
|
then
|
||||||
|
local expect_progress=N &&
|
||||||
|
shift
|
||||||
|
else
|
||||||
|
local expect_progress=
|
||||||
|
fi &&
|
||||||
|
|
||||||
|
if test $# -lt 1
|
||||||
|
then
|
||||||
|
BUG "no command given to test_delayed_checkout_progress"
|
||||||
|
fi &&
|
||||||
|
|
||||||
|
(
|
||||||
|
cd progress &&
|
||||||
|
GIT_PROGRESS_DELAY=0 &&
|
||||||
|
export GIT_PROGRESS_DELAY &&
|
||||||
|
rm -f *.a delay-progress.log &&
|
||||||
|
|
||||||
|
"$@" 2>err &&
|
||||||
|
grep "IN: smudge test-delay10.a .* \\[DELAYED\\]" delay-progress.log &&
|
||||||
|
if test "$expect_progress" = N
|
||||||
|
then
|
||||||
|
! grep "Filtering content" err
|
||||||
|
else
|
||||||
|
grep "Filtering content" err
|
||||||
|
fi
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
for mode in pathspec branch
|
||||||
|
do
|
||||||
|
case "$mode" in
|
||||||
|
pathspec) opt='.' ;;
|
||||||
|
branch) opt='-f HEAD' ;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
test_expect_success PERL,TTY "delayed checkout shows progress by default on tty ($mode checkout)" '
|
||||||
|
test_delayed_checkout_progress test_terminal git checkout $opt
|
||||||
|
'
|
||||||
|
|
||||||
|
test_expect_success PERL "delayed checkout ommits progress on non-tty ($mode checkout)" '
|
||||||
|
test_delayed_checkout_progress ! git checkout $opt
|
||||||
|
'
|
||||||
|
|
||||||
|
test_expect_success PERL,TTY "delayed checkout ommits progress with --quiet ($mode checkout)" '
|
||||||
|
test_delayed_checkout_progress ! test_terminal git checkout --quiet $opt
|
||||||
|
'
|
||||||
|
|
||||||
|
test_expect_success PERL,TTY "delayed checkout honors --[no]-progress ($mode checkout)" '
|
||||||
|
test_delayed_checkout_progress ! test_terminal git checkout --no-progress $opt &&
|
||||||
|
test_delayed_checkout_progress test_terminal git checkout --quiet --progress $opt
|
||||||
|
'
|
||||||
|
done
|
||||||
|
|
||||||
test_done
|
test_done
|
||||||
|
@ -479,7 +479,7 @@ static int check_updates(struct unpack_trees_options *o,
|
|||||||
errs |= run_parallel_checkout(&state, pc_workers, pc_threshold,
|
errs |= run_parallel_checkout(&state, pc_workers, pc_threshold,
|
||||||
progress, &cnt);
|
progress, &cnt);
|
||||||
stop_progress(&progress);
|
stop_progress(&progress);
|
||||||
errs |= finish_delayed_checkout(&state, NULL);
|
errs |= finish_delayed_checkout(&state, NULL, o->verbose_update);
|
||||||
git_attr_set_direction(GIT_ATTR_CHECKIN);
|
git_attr_set_direction(GIT_ATTR_CHECKIN);
|
||||||
|
|
||||||
if (o->clone)
|
if (o->clone)
|
||||||
|
Loading…
Reference in New Issue
Block a user