commit-graph: stop passing in redundant repository
Many of the commit-graph related functions take in both a repository and the object database source (directly or via `struct commit_graph`) for which we are supposed to load such a commit-graph. In the best case this information is simply redundant as the source already contains a reference to its owning object database, which in turn has a reference to its repository. In the worst case this information could even mismatch when passing in a source that doesn't belong to the same repository. Refactor the code so that we only pass in the object database source in those cases. There is one exception though, namely `load_commit_graph_chain_fd_st()`, which is responsible for loading a commit-graph chain. It is expected that parts of the commit-graph chain aren't located in the same object source as the chain file itself, but in a different one. Consequently, this function doesn't work on the source level but on the database level instead. Signed-off-by: Patrick Steinhardt <ps@pks.im> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
committed by
Junio C Hamano
parent
ddacfc7466
commit
7be9e410b2
@@ -122,15 +122,15 @@ static int graph_verify(int argc, const char **argv, const char *prefix,
|
||||
if (opened == OPENED_NONE)
|
||||
return 0;
|
||||
else if (opened == OPENED_GRAPH)
|
||||
graph = load_commit_graph_one_fd_st(the_repository, fd, &st, source);
|
||||
graph = load_commit_graph_one_fd_st(source, fd, &st);
|
||||
else
|
||||
graph = load_commit_graph_chain_fd_st(the_repository, fd, &st,
|
||||
graph = load_commit_graph_chain_fd_st(the_repository->objects, fd, &st,
|
||||
&incomplete_chain);
|
||||
|
||||
if (!graph)
|
||||
return 1;
|
||||
|
||||
ret = verify_commit_graph(the_repository, graph, flags);
|
||||
ret = verify_commit_graph(graph, flags);
|
||||
free_commit_graph(graph);
|
||||
|
||||
if (incomplete_chain) {
|
||||
|
||||
Reference in New Issue
Block a user