summaryrefslogtreecommitdiffstats
path: root/negotiator/skipping.c (follow)
Commit message (Collapse)AuthorAgeFilesLines
* Merge branch 'jt/fetch-negotiator-skipping'Junio C Hamano2018-08-031-1/+1
| | | | | | | | | | | Add a server-side knob to skip commits in exponential/fibbonacci stride in an attempt to cover wider swath of history with a smaller number of iterations, potentially accepting a larger packfile transfer, instead of going back one commit a time during common ancestor discovery during the "git fetch" transaction. * jt/fetch-negotiator-skipping: negotiator/skipping: skip commits during fetch
* negotiator/skipping: skip commits during fetchJonathan Tan2018-07-161-0/+250
Introduce a new negotiation algorithm used during fetch that skips commits in an effort to find common ancestors faster. The skips grow similarly to the Fibonacci sequence as the commit walk proceeds further away from the tips. The skips may cause unnecessary commits to be included in the packfile, but the negotiation step typically ends more quickly. Usage of this algorithm is guarded behind the configuration flag fetch.negotiationAlgorithm. Signed-off-by: Jonathan Tan <jonathantanmy@google.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>