From: "Derrick Stolee via GitGitGadget" <gitgitgadget@gmail.com>
To: git@vger.kernel.org
Cc: gitster@pobox.com, newren@gmail.com, vdye@github.com,
"Derrick Stolee" <stolee@gmail.com>,
"Ævar Arnfjörð Bjarmason" <avarab@gmail.com>,
"Derrick Stolee" <derrickstolee@github.com>
Subject: [PATCH v4 0/5] Sparse index: fetch, pull, ls-files
Date: Wed, 22 Dec 2021 14:20:51 +0000 [thread overview]
Message-ID: <pull.1080.v4.git.1640182856.gitgitgadget@gmail.com> (raw)
In-Reply-To: <pull.1080.v3.git.1639149192.gitgitgadget@gmail.com>
This is now based on 'master'.
Did you know that 'fetch' and 'pull' read the index? I didn't, or this would
have been an integration much earlier in the cycle. They read the index to
look for the .gitmodules file in case there are submodules that need to be
fetched. Since looking for a file by name is already protected, we only need
to disable 'command_requires_full_index' and we are done.
The 'ls-files' builtin is useful when debugging the index, and some scripts
use it, too. We are not changing the default behavior which expands a sparse
index in order to show all of the cached blobs. Instead, we add a '--sparse'
option that allows us to see the sparse directory entries upon request.
Combined with --debug, we can see a lot of index details, such as:
$ git ls-files --debug --sparse
LICENSE
ctime: 1634910503:287405820
mtime: 1634910503:287405820
dev: 16777220 ino: 119325319
uid: 501 gid: 20
size: 1098 flags: 200000
README.md
ctime: 1634910503:288090279
mtime: 1634910503:288090279
dev: 16777220 ino: 119325320
uid: 501 gid: 20
size: 934 flags: 200000
bin/index.js
ctime: 1634910767:828434033
mtime: 1634910767:828434033
dev: 16777220 ino: 119325520
uid: 501 gid: 20
size: 7292 flags: 200000
examples/
ctime: 0:0
mtime: 0:0
dev: 0 ino: 0
uid: 0 gid: 0
size: 0 flags: 40004000
package.json
ctime: 1634910503:288676330
mtime: 1634910503:288676330
dev: 16777220 ino: 119325321
uid: 501 gid: 20
size: 680 flags: 200000
(In this example, the 'examples/' directory is sparse.)
Thanks!
Updates in v2
=============
* Rebased onto latest ld/sparse-index-blame without issue.
* Updated the test to use diff-of-diffs instead of a sequence of greps.
* Added patches that remove the use of 'test-tool read-cache --table' and
its implementation.
Updates in v3
=============
* Fixed typo in commit message.
* Added comments around doing strange things in an ls-files test.
* Fixed adjacent typo in a test comment.
Updates in v4
=============
* Rebased on to 'master' now that ld/sparse-index-blame is merged.
* Change testing strategy to check exact output instead of using 'diff -u'.
* Updated documentation to state that directories have a trailing slash.
Derrick Stolee (5):
fetch/pull: use the sparse index
ls-files: add --sparse option
t1092: replace 'read-cache --table' with 'ls-files --sparse'
t1091/t3705: remove 'test-tool read-cache --table'
test-read-cache: remove --table, --expand options
Documentation/git-ls-files.txt | 5 +
builtin/fetch.c | 2 +
builtin/ls-files.c | 12 ++-
builtin/pull.c | 2 +
t/helper/test-read-cache.c | 64 ++---------
t/t1091-sparse-checkout-builtin.sh | 25 ++++-
t/t1092-sparse-checkout-compatibility.sh | 132 ++++++++++++++++++++---
t/t3705-add-sparse-checkout.sh | 8 +-
8 files changed, 168 insertions(+), 82 deletions(-)
base-commit: 597af311a2899bfd6640b9b107622c5795d5f998
Published-As: https://github.com/gitgitgadget/git/releases/tag/pr-1080%2Fderrickstolee%2Fsparse-index%2Ffetch-pull-ls-files-v4
Fetch-It-Via: git fetch https://github.com/gitgitgadget/git pr-1080/derrickstolee/sparse-index/fetch-pull-ls-files-v4
Pull-Request: https://github.com/gitgitgadget/git/pull/1080
Range-diff vs v3:
1: f72001638d1 = 1: 1043a1927d2 fetch/pull: use the sparse index
2: b81174ba54b ! 2: e1ec52881d9 ls-files: add --sparse option
@@ Documentation/git-ls-files.txt: Both the <eolinfo> in the index ("i/<eolinfo>")
+--sparse::
+ If the index is sparse, show the sparse directories without expanding
-+ to the contained files.
++ to the contained files. Sparse directories will be shown with a
++ trailing slash, such as "x/" for a sparse directory "x".
+
\--::
Do not interpret any more arguments as options.
@@ builtin/ls-files.c: int cmd_ls_files(int argc, const char **argv, const char *cm
## t/t1092-sparse-checkout-compatibility.sh ##
@@ t/t1092-sparse-checkout-compatibility.sh: test_expect_success 'sparse-index is expanded and converted back' '
- GIT_TRACE2_EVENT="$(pwd)/trace2.txt" GIT_TRACE2_EVENT_NESTING=10 \
+ GIT_TRACE2_EVENT="$(pwd)/trace2.txt" \
git -C sparse-index reset -- folder1/a &&
test_region index convert_to_sparse trace2.txt &&
+ test_region index ensure_full_index trace2.txt &&
@@ t/t1092-sparse-checkout-compatibility.sh: test_expect_success 'sparse index is n
+test_expect_success 'ls-files' '
+ init_repos &&
+
++ # Use a smaller sparse-checkout for reduced output
++ test_sparse_match git sparse-checkout set &&
++
+ # Behavior agrees by default. Sparse index is expanded.
+ test_all_match git ls-files &&
+
+ # With --sparse, the sparse index data changes behavior.
-+ git -C sparse-index ls-files >dense &&
-+ git -C sparse-index ls-files --sparse >sparse &&
++ git -C sparse-index ls-files --sparse >actual &&
+
+ cat >expect <<-\EOF &&
-+ @@ -13,13 +13,9 @@
-+ e
-+ folder1-
-+ folder1.x
-+ -folder1/0/0/0
-+ -folder1/0/1
-+ -folder1/a
-+ +folder1/
-+ folder10
-+ -folder2/0/0/0
-+ -folder2/0/1
-+ -folder2/a
-+ +folder2/
-+ g
-+ -x/a
-+ +x/
-+ z
++ a
++ deep/
++ e
++ folder1-
++ folder1.x
++ folder1/
++ folder10
++ folder2/
++ g
++ x/
++ z
+ EOF
+
-+ diff -u dense sparse | tail -n +3 >actual &&
+ test_cmp expect actual &&
+
+ # With --sparse and no sparse index, nothing changes.
@@ t/t1092-sparse-checkout-compatibility.sh: test_expect_success 'sparse index is n
+ test_sparse_match git sparse-checkout add folder1 &&
+ test_sparse_match git ls-files --modified &&
+
-+ git -C sparse-index ls-files >dense &&
-+ git -C sparse-index ls-files --sparse >sparse &&
++ test_all_match git ls-files &&
++ git -C sparse-index ls-files --sparse >actual &&
+
+ cat >expect <<-\EOF &&
-+ @@ -17,9 +17,7 @@
-+ folder1/0/1
-+ folder1/a
-+ folder10
-+ -folder2/0/0/0
-+ -folder2/0/1
-+ -folder2/a
-+ +folder2/
-+ g
-+ -x/a
-+ +x/
-+ z
++ a
++ deep/
++ e
++ folder1-
++ folder1.x
++ folder1/0/0/0
++ folder1/0/1
++ folder1/a
++ folder10
++ folder2/
++ g
++ x/
++ z
+ EOF
+
-+ diff -u dense sparse | tail -n +3 >actual &&
+ test_cmp expect actual &&
+
+ # Double-check index expansion is avoided
3: 2a6a1c5a39c = 3: 0c53bd09ba4 t1092: replace 'read-cache --table' with 'ls-files --sparse'
4: f0143686754 = 4: 4952c9e724b t1091/t3705: remove 'test-tool read-cache --table'
5: 9227dc54165 = 5: 3efffad814c test-read-cache: remove --table, --expand options
--
gitgitgadget
next prev parent reply other threads:[~2021-12-22 14:21 UTC|newest]
Thread overview: 51+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-11-16 15:38 [PATCH 0/2] Sparse index: fetch, pull, ls-files Derrick Stolee via GitGitGadget
2021-11-16 15:38 ` [PATCH 1/2] fetch/pull: use the sparse index Derrick Stolee via GitGitGadget
2021-11-16 15:38 ` [PATCH 2/2] ls-files: add --sparse option Derrick Stolee via GitGitGadget
2021-11-22 18:36 ` Elijah Newren
2021-11-22 19:44 ` Derrick Stolee
2021-11-23 2:07 ` Ævar Arnfjörð Bjarmason
2021-12-08 15:14 ` Derrick Stolee
2021-12-08 15:20 ` Derrick Stolee
2021-12-08 17:04 ` Elijah Newren
2021-12-08 18:23 ` Derrick Stolee
2021-12-08 18:36 ` Elijah Newren
2021-12-08 19:06 ` Derrick Stolee
2021-12-09 12:50 ` Ævar Arnfjörð Bjarmason
2021-12-10 13:57 ` Derrick Stolee
2021-12-10 15:13 ` Ævar Arnfjörð Bjarmason
2021-12-13 19:16 ` Junio C Hamano
2021-12-16 14:11 ` Derrick Stolee
2021-11-17 9:29 ` [PATCH 0/2] Sparse index: fetch, pull, ls-files Junio C Hamano
2021-11-17 15:28 ` Derrick Stolee
2021-11-18 22:13 ` Junio C Hamano
2021-11-23 1:57 ` Ævar Arnfjörð Bjarmason
2021-12-08 19:39 ` [PATCH v2 0/5] " Derrick Stolee via GitGitGadget
2021-12-08 19:39 ` [PATCH v2 1/5] fetch/pull: use the sparse index Derrick Stolee via GitGitGadget
2021-12-08 19:39 ` [PATCH v2 2/5] ls-files: add --sparse option Derrick Stolee via GitGitGadget
2021-12-09 5:08 ` Elijah Newren
2021-12-10 13:51 ` Derrick Stolee
2021-12-08 19:39 ` [PATCH v2 3/5] t1092: replace 'read-cache --table' with 'ls-files --sparse' Derrick Stolee via GitGitGadget
2021-12-09 5:19 ` Elijah Newren
2021-12-08 19:39 ` [PATCH v2 4/5] t1091/t3705: remove 'test-tool read-cache --table' Derrick Stolee via GitGitGadget
2021-12-09 5:20 ` Elijah Newren
2021-12-08 19:39 ` [PATCH v2 5/5] test-read-cache: remove --table, --expand options Derrick Stolee via GitGitGadget
2021-12-09 5:23 ` [PATCH v2 0/5] Sparse index: fetch, pull, ls-files Elijah Newren
2021-12-10 15:13 ` [PATCH v3 " Derrick Stolee via GitGitGadget
2021-12-10 15:13 ` [PATCH v3 1/5] fetch/pull: use the sparse index Derrick Stolee via GitGitGadget
2021-12-10 15:13 ` [PATCH v3 2/5] ls-files: add --sparse option Derrick Stolee via GitGitGadget
2021-12-10 15:13 ` [PATCH v3 3/5] t1092: replace 'read-cache --table' with 'ls-files --sparse' Derrick Stolee via GitGitGadget
2021-12-10 15:13 ` [PATCH v3 4/5] t1091/t3705: remove 'test-tool read-cache --table' Derrick Stolee via GitGitGadget
2021-12-10 15:13 ` [PATCH v3 5/5] test-read-cache: remove --table, --expand options Derrick Stolee via GitGitGadget
2021-12-10 16:16 ` [PATCH v3 0/5] Sparse index: fetch, pull, ls-files Ævar Arnfjörð Bjarmason
2021-12-10 18:45 ` Elijah Newren
2021-12-11 2:24 ` Ævar Arnfjörð Bjarmason
2021-12-11 4:45 ` Elijah Newren
2021-12-10 18:53 ` Elijah Newren
2021-12-22 14:20 ` Derrick Stolee via GitGitGadget [this message]
2021-12-22 14:20 ` [PATCH v4 1/5] fetch/pull: use the sparse index Derrick Stolee via GitGitGadget
2021-12-22 14:20 ` [PATCH v4 2/5] ls-files: add --sparse option Derrick Stolee via GitGitGadget
2021-12-22 14:20 ` [PATCH v4 3/5] t1092: replace 'read-cache --table' with 'ls-files --sparse' Derrick Stolee via GitGitGadget
2021-12-22 14:20 ` [PATCH v4 4/5] t1091/t3705: remove 'test-tool read-cache --table' Derrick Stolee via GitGitGadget
2021-12-22 14:20 ` [PATCH v4 5/5] test-read-cache: remove --table, --expand options Derrick Stolee via GitGitGadget
2021-12-22 19:17 ` [PATCH v4 0/5] Sparse index: fetch, pull, ls-files Elijah Newren
2021-12-22 23:56 ` Junio C Hamano
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
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=pull.1080.v4.git.1640182856.gitgitgadget@gmail.com \
--to=gitgitgadget@gmail.com \
--cc=avarab@gmail.com \
--cc=derrickstolee@github.com \
--cc=git@vger.kernel.org \
--cc=gitster@pobox.com \
--cc=newren@gmail.com \
--cc=stolee@gmail.com \
--cc=vdye@github.com \
/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
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
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 NNTP newsgroup(s).