Skip to content

Commit b5651a2

Browse files
jrngitster
authored andcommitted
experimental: default to fetch.writeCommitGraph=false
The fetch.writeCommitGraph feature makes fetches write out a commit graph file for the newly downloaded pack on fetch. This improves the performance of various commands that would perform a revision walk and eventually ought to be the default for everyone. To prepare for that future, it's enabled by default for users that set feature.experimental=true to experience such future defaults. Alas, for --unshallow fetches from a shallow clone it runs into a snag: by the time Git has fetched the new objects and is writing a commit graph, it has performed a revision walk and r->parsed_objects contains information about the shallow boundary from *before* the fetch. The commit graph writing code is careful to avoid writing a commit graph file in shallow repositories, but the new state is not shallow, and the result is that from that point on, commands like "git log" make use of a newly written commit graph file representing a fictional history with the old shallow boundary. We could fix this by making the commit graph writing code more careful to avoid writing a commit graph that could have used any grafts or shallow state, but it is possible that there are other pieces of mutated state that fetch's commit graph writing code may be relying on. So disable it in the feature.experimental configuration. Google developers have been running in this configuration (by setting fetch.writeCommitGraph=false in the system config) to work around this bug since it was discovered in April. Once the fix lands, we'll enable fetch.writeCommitGraph=true again to give it some early testing before rolling out to a wider audience. In other words: - this patch only affects behavior with feature.experimental=true - it makes feature.experimental match the configuration Google has been using for the last few months, meaning it would leave users in a better tested state than without it - this should improve testing for other features guarded by feature.experimental, by making feature.experimental safer to use Reported-by: Jay Conrod <[email protected]> Helped-by: Taylor Blau <[email protected]> Signed-off-by: Jonathan Nieder <[email protected]> Signed-off-by: Junio C Hamano <[email protected]>
1 parent 4a0fcf9 commit b5651a2

File tree

3 files changed

+5
-14
lines changed

3 files changed

+5
-14
lines changed

Documentation/config/feature.txt

Lines changed: 0 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -15,14 +15,6 @@ feature.experimental::
1515
* `fetch.negotiationAlgorithm=skipping` may improve fetch negotiation times by
1616
skipping more commits at a time, reducing the number of round trips.
1717
+
18-
* `fetch.writeCommitGraph=true` writes a commit-graph after every `git fetch`
19-
command that downloads a pack-file from a remote. Using the `--split` option,
20-
most executions will create a very small commit-graph file on top of the
21-
existing commit-graph file(s). Occasionally, these files will merge and the
22-
write may take longer. Having an updated commit-graph file helps performance
23-
of many Git commands, including `git merge-base`, `git push -f`, and
24-
`git log --graph`.
25-
+
2618
* `protocol.version=2` speeds up fetches from repositories with many refs by
2719
allowing the client to specify which refs to list before the server lists
2820
them.

Documentation/config/fetch.txt

Lines changed: 1 addition & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -90,5 +90,4 @@ fetch.writeCommitGraph::
9090
the existing commit-graph file(s). Occasionally, these files will
9191
merge and the write may take longer. Having an updated commit-graph
9292
file helps performance of many Git commands, including `git merge-base`,
93-
`git push -f`, and `git log --graph`. Defaults to false, unless
94-
`feature.experimental` is true.
93+
`git push -f`, and `git log --graph`. Defaults to false.

repo-settings.c

Lines changed: 4 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -51,14 +51,14 @@ void prepare_repo_settings(struct repository *r)
5151
UPDATE_DEFAULT_BOOL(r->settings.index_version, 4);
5252
UPDATE_DEFAULT_BOOL(r->settings.core_untracked_cache, UNTRACKED_CACHE_WRITE);
5353
}
54+
5455
if (!repo_config_get_bool(r, "fetch.writecommitgraph", &value))
5556
r->settings.fetch_write_commit_graph = value;
56-
if (!repo_config_get_bool(r, "feature.experimental", &value) && value) {
57-
UPDATE_DEFAULT_BOOL(r->settings.fetch_negotiation_algorithm, FETCH_NEGOTIATION_SKIPPING);
58-
UPDATE_DEFAULT_BOOL(r->settings.fetch_write_commit_graph, 1);
59-
}
6057
UPDATE_DEFAULT_BOOL(r->settings.fetch_write_commit_graph, 0);
6158

59+
if (!repo_config_get_bool(r, "feature.experimental", &value) && value)
60+
UPDATE_DEFAULT_BOOL(r->settings.fetch_negotiation_algorithm, FETCH_NEGOTIATION_SKIPPING);
61+
6262
/* Hack for test programs like test-dump-untracked-cache */
6363
if (ignore_untracked_cache_config)
6464
r->settings.core_untracked_cache = UNTRACKED_CACHE_KEEP;

0 commit comments

Comments
 (0)