зеркало из https://github.com/microsoft/git.git
read-cache: set sparsity when index is new
When the index read in 'do_read_index()' does not exist on-disk, mark the index "sparse" if the executing command does not require a full index and sparse index is otherwise enabled. Some commands (such as 'git stash -u') implicitly create a new index (when the 'GIT_INDEX_FILE' variable points to a non-existent file) and perform some operation on it. However, when this index is created, it isn't created with the same sparsity settings as the repo index. As a result, while these indexes may be sparse during the operation, they are always expanded before being written to disk. We can avoid that expansion by defaulting the index to "sparse", in which case it will only be expanded if the full index is needed. Note that the function 'set_new_index_sparsity()' is created despite having only a single caller because additional callers will be added in a subsequent patch. Signed-off-by: Victoria Dye <vdye@github.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Родитель
cfde4cd6ff
Коммит
491df5f679
18
read-cache.c
18
read-cache.c
|
@ -2260,6 +2260,20 @@ static unsigned long load_cache_entries_threaded(struct index_state *istate, con
|
||||||
return consumed;
|
return consumed;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void set_new_index_sparsity(struct index_state *istate)
|
||||||
|
{
|
||||||
|
/*
|
||||||
|
* If the index's repo exists, mark it sparse according to
|
||||||
|
* repo settings.
|
||||||
|
*/
|
||||||
|
if (istate->repo) {
|
||||||
|
prepare_repo_settings(istate->repo);
|
||||||
|
if (!istate->repo->settings.command_requires_full_index &&
|
||||||
|
is_sparse_index_allowed(istate, 0))
|
||||||
|
istate->sparse_index = 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/* remember to discard_cache() before reading a different cache! */
|
/* remember to discard_cache() before reading a different cache! */
|
||||||
int do_read_index(struct index_state *istate, const char *path, int must_exist)
|
int do_read_index(struct index_state *istate, const char *path, int must_exist)
|
||||||
{
|
{
|
||||||
|
@ -2281,8 +2295,10 @@ int do_read_index(struct index_state *istate, const char *path, int must_exist)
|
||||||
istate->timestamp.nsec = 0;
|
istate->timestamp.nsec = 0;
|
||||||
fd = open(path, O_RDONLY);
|
fd = open(path, O_RDONLY);
|
||||||
if (fd < 0) {
|
if (fd < 0) {
|
||||||
if (!must_exist && errno == ENOENT)
|
if (!must_exist && errno == ENOENT) {
|
||||||
|
set_new_index_sparsity(istate);
|
||||||
return 0;
|
return 0;
|
||||||
|
}
|
||||||
die_errno(_("%s: index file open failed"), path);
|
die_errno(_("%s: index file open failed"), path);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1389,7 +1389,7 @@ test_expect_success 'sparse-index is not expanded: stash' '
|
||||||
ensure_not_expanded stash drop stash@{0} &&
|
ensure_not_expanded stash drop stash@{0} &&
|
||||||
|
|
||||||
echo >>sparse-index/deep/new &&
|
echo >>sparse-index/deep/new &&
|
||||||
! ensure_not_expanded stash -u &&
|
ensure_not_expanded stash -u &&
|
||||||
(
|
(
|
||||||
WITHOUT_UNTRACKED_TXT=1 &&
|
WITHOUT_UNTRACKED_TXT=1 &&
|
||||||
! ensure_not_expanded stash pop
|
! ensure_not_expanded stash pop
|
||||||
|
|
Загрузка…
Ссылка в новой задаче