Conversation
When prefetching the commit graph for the first time with `trust-pack-indexes=false`, the first pack file is the largest and takes the longest to index. In my test case, it takes ~2 minutes to fetch all the pack files, ~13 minutes to index the first pack file, and less than 1 minute to index the rest. A previous pull request parallelized the pack file indexing. This pull request makes it so as soon as the smaller, more recent pack files are ready they are moved into the live pack folder and can be accessed by the user's operations. A marker file is created when a pack file is moved into the live pack folder ahead of an older pack file still indexing. If the prefetch is interrupted, the next prefetch will ignore pack files which have the marker when determining the timestamp for the prefetch, which ensures that any missing pack files from the interrupted prefetch are redownloaded. The marker file is deleted once all the previous pack files are ready. After a completed prefetch, any markers (and the pack and index files they mark) left over from previous incomplete prefetches are deleted.
Make ready pack files available during prefetch
The previous implementation of GetHeadTreeId called "git show -s". "-s" suppresses the diff from the output, but it turns out git still performs the diff operation internally. The inefficiency isn't necessarily an issue, but we are running git.exe with the virtualization hook off so if the objects required for the diff are not already downloaded the command will fail. The new implementation produces the same output, but doesn't try to do a diff at all.
Fix GetHeadTreeId to only read head commit
tyrielv
approved these changes
Dec 16, 2025
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
Changes: