Go to file
Derrick Stolee e2164742c9 fetch: add --negotiation-include option for negotiation
Add a new --negotiation-include option to 'git fetch', which ensures
that certain ref tips are always sent as 'have' lines during fetch
negotiation, regardless of what the negotiation algorithm selects.

This is useful when the repository has a large number of references, so
the normal negotiation algorithm truncates the list. This is especially
important in repositories with long parallel commit histories. For
example, a repo could have a 'dev' branch for development and a
'release' branch for released versions. If the 'dev' branch isn't
selected for negotiation, then it's not a big deal because there are
many in-progress development branches with a shared history. However, if
'release' is not selected for negotiation, then the server may think
that this is the first time the client has asked for that reference,
causing a full download of its parallel commit history (and any extra
data that may be unique to that branch). This is based on a real example
where certain fetches would grow to 60+ GB when a release branch
updated.

This option is a complement to --negotiation-restrict, which reduces the
negotiation ref set to a specific list. In the earlier example, using
--negotiation-restrict to focus the negotiation to 'dev' and 'release'
would avoid those problematic downloads, but would still not allow
advertising potentially-relevant user branches. In this way, the
'include' version solves the problem I mention while allowing
negotiation to pick other references opportunistically. The two options
can also be combined to allow the best of both worlds.

The argument may be an exact ref name or a glob pattern. Non-existent
refs are silently ignored. This behavior is also updated in the ref matching
logic for the related --negotiation-restrict option to match.

The implementation outputs the requested objects as haves before the
negotiator performs its own algorithm to choose the next haves. Use the new
have_sent() interface to signal these have commits were sent before engaging
with the negotiator's next() iterator.

Also add --negotiation-include to 'git pull' passthrough options.

Reviewed-by: Matthew John Cheetham <mjcheetham@outlook.com>
Signed-off-by: Derrick Stolee <stolee@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
2026-05-20 11:33:24 +09:00
.github Merge branch 'ps/ci-gitlab-msvc-updates' 2026-02-27 15:11:52 -08:00
Documentation fetch: add --negotiation-include option for negotiation 2026-05-20 11:33:24 +09:00
bin-wrappers
block-sha1
builtin fetch: add --negotiation-include option for negotiation 2026-05-20 11:33:24 +09:00
ci Merge branch 'ps/ci-reduce-gitlab-envsize' 2026-03-10 14:23:21 -07:00
compat Merge branch 'mc/tr2-process-ancestry-cleanup' 2026-02-25 11:54:18 -08:00
compiler-tricks
contrib Merge branch 'kn/osxkeychain-buildfix' 2026-03-04 10:52:59 -08:00
ewah cocci: extend MEMZERO_ARRAY() rules 2026-02-03 09:41:52 -08:00
git-gui Merge branch 'master' of https://github.com/j6t/git-gui 2026-03-21 09:25:58 -07:00
gitk-git Merge branch 'master' of https://github.com/j6t/gitk 2026-03-21 09:25:10 -07:00
gitweb gitweb: let page header grow on mobile for long wrapped project names 2026-02-17 11:49:13 -08:00
mergetools
negotiator negotiator: add have_sent() interface 2026-05-20 11:33:24 +09:00
odb odb/source: make `begin_transaction()` function pluggable 2026-03-05 11:45:17 -08:00
oss-fuzz environment: stop storing `core.attributesFile` globally 2026-02-17 12:09:42 -08:00
perl
po Merge branch 'jx/i18n-fix' of github.com:jiangxin/gitk 2026-03-20 09:23:32 +01:00
refs Merge branch 'ps/refs-for-each' 2026-03-09 14:36:55 -07:00
reftable reftable/stack: add function to check if optimization is required 2025-11-10 09:28:47 -08:00
sha1
sha1collisiondetection@855827c583
sha1dc
sha256
src rust: add a small wrapper around the hashfile code 2026-02-07 17:41:03 -08:00
subprojects meson: wire up gitk and git-gui 2026-02-04 09:42:50 -08:00
t fetch: add --negotiation-include option for negotiation 2026-05-20 11:33:24 +09:00
templates Merge branch 'pt/fsmonitor-watchman-sample-fix' 2026-03-10 14:23:23 -07:00
trace2
xdiff Merge branch 'pw/diff-anchored-optim' 2026-02-20 11:36:18 -08:00
.cirrus.yml
.clang-format clang-format: exclude control macros from SpaceBeforeParens 2025-09-28 08:37:23 -07:00
.editorconfig editorconfig: fix style not applying to subdirs anymore 2026-03-11 10:30:51 -07:00
.gitattributes templates: add .gitattributes entry for sample hooks 2026-02-13 09:26:11 -08:00
.gitignore gitk: ignore generated POT file 2026-03-20 09:31:04 +08:00
.gitlab-ci.yml Merge branch 'ps/ci-gitlab-prepare-for-macos-14-deprecation' 2026-03-12 10:56:04 -07:00
.gitmodules
.mailmap .mailmap: update email address for Tian Yuchen 2026-03-09 12:46:34 -07:00
.tsan-suppressions
CODE_OF_CONDUCT.md
COPYING
Cargo.toml ci: verify minimum supported Rust version 2025-10-15 08:10:17 -07:00
GIT-BUILD-OPTIONS.in
GIT-VERSION-FILE.in
GIT-VERSION-GEN git-gui: fix use of GIT_CEILING_DIRECTORIES 2026-02-17 06:58:00 +01:00
INSTALL
LGPL-2.1
Makefile Merge branch 'jx/i18n-fix' of github.com:jiangxin/gitk 2026-03-20 09:23:32 +01:00
README.md gitk: add README with usage, build, and contribution details 2025-08-28 19:51:31 +02:00
RelNotes Start 2.54 cycle 2026-02-05 15:42:01 -08:00
SECURITY.md
abspath.c
abspath.h
aclocal.m4
add-interactive.c Merge branch 'aa/add-p-no-auto-advance' 2026-03-03 11:08:13 -08:00
add-interactive.h interactive -p: add new `--auto-advance` flag 2026-02-17 10:48:36 -08:00
add-patch.c Merge branch 'aa/add-p-no-auto-advance' 2026-03-03 11:08:13 -08:00
advice.c initial branch: give hints after switching the default name 2025-09-18 11:44:47 -07:00
advice.h initial branch: give hints after switching the default name 2025-09-18 11:44:47 -07:00
alias.c alias: treat empty subsection [alias ""] as plain [alias] 2026-02-26 13:06:49 -08:00
alias.h
alloc.c alloc: fix dangling pointer in alloc_state cleanup 2025-09-04 15:24:16 -07:00
alloc.h alloc: fix dangling pointer in alloc_state cleanup 2025-09-04 15:24:16 -07:00
apply.c Merge branch 'jr/apply-directory-normalize' 2026-03-04 10:53:01 -08:00
apply.h
archive-tar.c streaming: drop redundant type and size pointers 2025-11-23 12:56:46 -08:00
archive-zip.c streaming: drop redundant type and size pointers 2025-11-23 12:56:46 -08:00
archive.c cocci: convert parse_tree functions to repo_ variants 2026-01-09 18:36:18 -08:00
archive.h
attr.c environment: stop storing `core.attributesFile` globally 2026-02-17 12:09:42 -08:00
attr.h
banned.h banned.h: ban mktemp(3) 2025-12-07 07:28:13 +09:00
base85.c
base85.h
bisect.c Merge branch 'ps/for-each-ref-in-fixes' 2026-02-27 15:11:50 -08:00
bisect.h
blame.c commit: rename `free_commit_list()` to conform to coding guidelines 2026-01-15 05:32:31 -08:00
blame.h
blob.c
blob.h
bloom.c bloom: use repo_parse_tree() 2026-01-09 18:36:16 -08:00
bloom.h
branch.c branch: advice using git-help(1) instead of man(1) 2025-12-03 00:16:05 -08:00
branch.h environment: move "branch.autoSetupMerge" into `struct repo_config_values` 2026-02-26 07:22:53 -08:00
build.rs rust: add a build.rs script for tests 2026-02-07 17:41:03 -08:00
builtin.h Merge branch 'ps/history' 2026-02-09 12:09:09 -08:00
bundle-uri.c bundle-uri: validate that bundle entries have a uri 2025-12-20 14:45:27 +09:00
bundle-uri.h
bundle.c
bundle.h
cache-tree.c cocci: convert parse_tree functions to repo_ variants 2026-01-09 18:36:18 -08:00
cache-tree.h
cbtree.c
cbtree.h
chdir-notify.c chdir-notify: add function to unregister listeners 2025-11-25 12:16:00 -08:00
chdir-notify.h chdir-notify: add function to unregister listeners 2025-11-25 12:16:00 -08:00
check-builtins.sh
checkout.c
checkout.h
chunk-format.c
chunk-format.h
color.c color: add color_parse_quietly() 2026-02-23 13:23:41 -08:00
color.h color: add color_parse_quietly() 2026-02-23 13:23:41 -08:00
column.c
column.h
combine-diff.c Merge branch 'tc/last-modified-recursive-fix' 2025-09-29 11:40:35 -07:00
command-list.txt builtin: add new "history" command 2026-01-13 05:41:17 -08:00
commit-graph.c odb: embed base source in the "files" backend 2026-03-05 11:45:15 -08:00
commit-graph.h commit-graph: return commit graph from `repo_find_commit_pos_in_graph()` 2025-09-04 16:16:22 -07:00
commit-reach.c commit: rename `free_commit_list()` to conform to coding guidelines 2026-01-15 05:32:31 -08:00
commit-reach.h
commit-slab-decl.h
commit-slab-impl.h
commit-slab.h
commit.c Merge branch 'ps/receive-pack-shallow-optim' 2026-03-02 17:06:53 -08:00
commit.h Merge branch 'ps/receive-pack-shallow-optim' 2026-03-02 17:06:53 -08:00
common-exit.c
common-init.c
common-init.h
common-main.c
config.c global: constify some pointers that are not written to 2026-02-05 17:52:49 -08:00
config.h config: mark otherwise unused function as file-scope static 2025-11-20 15:03:40 -08:00
config.mak.dev
config.mak.in
config.mak.uname Merge branch 'mc/tr2-process-ancestry-cleanup' 2026-02-25 11:54:18 -08:00
configure.ac
connect.c promisor-remote: change promisor_remote_reply()'s signature 2026-02-17 11:46:41 -08:00
connect.h
connected.c check_connected(): fix leak of pack-index mmap 2026-03-06 13:51:03 -08:00
connected.h
convert.c global: constify some pointers that are not written to 2026-02-05 17:52:49 -08:00
convert.h
copy.c
copy.h
credential.c
credential.h
csum-file.c csum-file: define hashwrite's count as a uint32_t 2026-02-07 17:41:02 -08:00
csum-file.h csum-file: define hashwrite's count as a uint32_t 2026-02-07 17:41:02 -08:00
ctype.c
daemon.c
date.c
date.h
decorate.c
decorate.h
delta-islands.c delta-islands: use repo_parse_tree() 2026-01-09 18:36:17 -08:00
delta-islands.h
delta.h
detect-compiler
diagnose.c
diagnose.h
diff-delta.c git-compat-util: introduce MEMZERO_ARRAY() macro 2025-12-11 14:44:43 +09:00
diff-lib.c Merge branch 'ps/commit-list-functions-renamed' 2026-02-13 13:39:25 -08:00
diff-merges.c
diff-merges.h
diff-no-index.c diff --no-index: fix logic for paths ending in '/' 2025-09-25 11:35:20 -07:00
diff.c Merge branch 'mm/diff-no-index-find-object' 2026-03-10 14:23:22 -07:00
diff.h Merge branch 'rs/diff-index-find-copies-harder-optim' 2025-12-14 17:04:36 +09:00
diffcore-break.c Merge branch 'en/merge-ort-almost-wo-the-repository' 2026-03-04 10:53:02 -08:00
diffcore-delta.c cocci: extend MEMZERO_ARRAY() rules 2026-02-03 09:41:52 -08:00
diffcore-order.c
diffcore-pickaxe.c
diffcore-rename.c merge,diff: remove the_repository check before prefetching blobs 2026-02-21 18:34:06 -08:00
diffcore-rotate.c
diffcore.h
dir-iterator.c
dir-iterator.h
dir.c environment: stop using core.sparseCheckout globally 2026-02-26 07:22:51 -08:00
dir.h dir: add generic "walk all files" helper 2025-09-12 08:59:52 -07:00
editor.c
editor.h
entry.c streaming: move into object database subsystem 2025-11-23 12:56:46 -08:00
entry.h
environment.c Merge branch 'ob/core-attributesfile-in-repository' 2026-03-05 10:04:49 -08:00
environment.h Merge branch 'ob/core-attributesfile-in-repository' 2026-03-05 10:04:49 -08:00
exec-cmd.c
exec-cmd.h
fetch-negotiator.c
fetch-negotiator.h negotiator: add have_sent() interface 2026-05-20 11:33:24 +09:00
fetch-pack.c fetch: add --negotiation-include option for negotiation 2026-05-20 11:33:24 +09:00
fetch-pack.h fetch: add --negotiation-include option for negotiation 2026-05-20 11:33:24 +09:00
fmt-merge-msg.c Merge branch 'ps/commit-list-functions-renamed' 2026-02-13 13:39:25 -08:00
fmt-merge-msg.h environment: remove the global variable 'merge_log_config' 2025-08-11 09:16:55 -07:00
for-each-ref.h Merge branch 'ja/doc-lint-sections-and-synopsis' 2025-08-25 14:22:02 -07:00
fsck.c global: constify some pointers that are not written to 2026-02-05 17:52:49 -08:00
fsck.h builtin/fsck: move generic HEAD check into `refs_fsck()` 2026-01-12 06:55:41 -08:00
fsmonitor--daemon.h
fsmonitor-ipc.c
fsmonitor-ipc.h
fsmonitor-ll.h
fsmonitor-path-utils.h
fsmonitor-settings.c
fsmonitor-settings.h
fsmonitor.c
fsmonitor.h
generate-cmdlist.sh
generate-configlist.sh build: regenerate config-list.h when Documentation changes 2026-02-24 10:51:54 -08:00
generate-hooklist.sh
generate-perl.sh perl: also mark git-contacts executable 2025-11-06 09:57:47 -08:00
generate-python.sh
generate-script.sh
gettext.c
gettext.h
git-archimport.perl
git-compat-util.h environment: move access to core.maxTreeDepth into repo settings 2026-01-09 18:36:16 -08:00
git-curl-compat.h curl: add support for curl_global_trace() components 2025-08-27 09:49:43 -07:00
git-cvsexportcommit.perl
git-cvsimport.perl
git-cvsserver.perl
git-difftool--helper.sh
git-filter-branch.sh
git-instaweb.sh
git-merge-octopus.sh
git-merge-one-file.sh
git-merge-resolve.sh
git-mergetool--lib.sh
git-mergetool.sh
git-p4.py
git-quiltimport.sh
git-request-pull.sh
git-send-email.perl Merge branch 'sp/send-email-validate-charset' 2026-03-12 10:56:05 -07:00
git-sh-i18n.sh
git-sh-setup.sh
git-submodule.sh
git-svn.perl
git-web--browse.sh
git-zlib.c
git-zlib.h
git.c Merge branch 'jh/alias-i18n-fixes' 2026-03-10 14:23:24 -07:00
git.rc.in
gpg-interface.c Merge branch 'uk/signature-is-good-after-key-expires' 2026-03-02 17:06:50 -08:00
gpg-interface.h Merge branch 'cc/fast-import-strip-if-invalid' 2025-12-05 14:49:58 +09:00
graph.c
graph.h
grep.c grep: don't treat grep_opt.color as a strict bool 2025-09-16 13:37:05 -07:00
grep.h color: use git_colorbool enum type to store colorbools 2025-09-16 17:59:53 -07:00
hash-lookup.c
hash-lookup.h
hash.c hash: expose hash context functions to Rust 2026-02-07 17:41:02 -08:00
hash.h hash: expose hash context functions to Rust 2026-02-07 17:41:02 -08:00
hashmap.c git-compat-util: introduce MEMZERO_ARRAY() macro 2025-12-11 14:44:43 +09:00
hashmap.h
help.c Merge branch 'jh/alias-i18n-fixes' 2026-03-10 14:23:24 -07:00
help.h
hex-ll.c
hex-ll.h
hex.c
hex.h
hook.c hook: allow out-of-repo 'git hook' invocations 2026-02-19 13:24:39 -08:00
hook.h hook: include hooks from the config 2026-02-19 13:23:41 -08:00
http-backend.c refs: replace `refs_for_each_namespaced_ref()` 2026-02-23 13:21:19 -08:00
http-fetch.c
http-push.c global: constify some pointers that are not written to 2026-02-05 17:52:49 -08:00
http-walker.c http: refactor subsystem to use `packfile_list`s 2025-10-30 07:09:52 -07:00
http.c odb: embed base source in the "files" backend 2026-03-05 11:45:15 -08:00
http.h http: refactor subsystem to use `packfile_list`s 2025-10-30 07:09:52 -07:00
ident.c Merge branch 'ps/reflog-migrate-fixes' into maint-2.51 2025-10-15 10:29:28 -07:00
ident.h ident: fix type of string length parameter 2025-08-06 07:36:30 -07:00
imap-send.c Merge branch 'js/curl-off-t-fixes' into maint-2.51 2025-10-14 13:40:53 -07:00
iterator.h
json-writer.c
json-writer.h
khash.h
kwset.c
kwset.h
levenshtein.c
levenshtein.h
line-log.c commit: rename `free_commit_list()` to conform to coding guidelines 2026-01-15 05:32:31 -08:00
line-log.h
line-range.c
line-range.h
linear-assignment.c cocci: use MEMZERO_ARRAY() a bit more 2025-12-13 10:47:59 +09:00
linear-assignment.h
list-objects-filter-options.c list-objects-filter-options: avoid strbuf_split_str() 2026-03-11 11:08:53 -07:00
list-objects-filter-options.h list-objects-filter-options: support 'auto' mode for --filter 2026-02-17 11:46:40 -08:00
list-objects-filter.c list-objects-filter-options: support 'auto' mode for --filter 2026-02-17 11:46:40 -08:00
list-objects-filter.h
list-objects.c cocci: convert parse_tree functions to repo_ variants 2026-01-09 18:36:18 -08:00
list-objects.h
list.h
lockfile.c Merge branch 'pc/lockfile-pid' 2026-02-17 13:30:41 -08:00
lockfile.h lockfile: add PID file for debugging stale locks 2026-01-22 12:15:46 -08:00
log-tree.c commit: rename `free_commit_list()` to conform to coding guidelines 2026-01-15 05:32:31 -08:00
log-tree.h color: use git_colorbool enum type to store colorbools 2025-09-16 17:59:53 -07:00
loose.c odb: embed base source in the "files" backend 2026-03-05 11:45:15 -08:00
loose.h
ls-refs.c refs: generalize `refs_for_each_fullref_in_prefixes()` 2026-02-23 13:21:18 -08:00
ls-refs.h
mailinfo.c global: constify some pointers that are not written to 2026-02-05 17:52:49 -08:00
mailinfo.h
mailmap.c mailmap: drop global config variables 2026-02-20 08:13:58 -08:00
mailmap.h mailmap: drop global config variables 2026-02-20 08:13:58 -08:00
match-trees.c
match-trees.h
mem-pool.c global: constify some pointers that are not written to 2026-02-05 17:52:49 -08:00
mem-pool.h
merge-blobs.c
merge-blobs.h
merge-ll.c
merge-ll.h
merge-ort-wrappers.c commit: rename `free_commit_list()` to conform to coding guidelines 2026-01-15 05:32:31 -08:00
merge-ort-wrappers.h
merge-ort.c merge-ort: prevent the_repository from coming back 2026-02-21 18:34:07 -08:00
merge-ort.h
merge.c cocci: convert parse_tree functions to repo_ variants 2026-01-09 18:36:18 -08:00
merge.h
mergesort.h
meson.build Merge branch 'jk/unleak-mmap' 2026-03-16 10:48:15 -07:00
meson_options.txt git-gui: fix use of GIT_CEILING_DIRECTORIES 2026-02-17 06:58:00 +01:00
midx-write.c Merge branch 'tb/midx-write-corrupt-checksum-fix' 2026-01-21 16:16:27 -08:00
midx.c odb: embed base source in the "files" backend 2026-03-05 11:45:15 -08:00
midx.h packfile: move `get_multi_pack_index()` into "midx.c" 2025-09-24 11:53:50 -07:00
name-hash.c
name-hash.h
notes-cache.c
notes-cache.h
notes-merge.c Merge branch 'rs/xdiff-wo-the-repository' 2026-02-17 13:30:42 -08:00
notes-merge.h
notes-utils.c commit: rename `free_commit_list()` to conform to coding guidelines 2026-01-15 05:32:31 -08:00
notes-utils.h
notes.c refs: replace `refs_for_each_glob_ref()` 2026-02-23 13:21:19 -08:00
notes.h
object-file-convert.c Merge branch 'bc/sha1-256-interop-02' 2026-03-12 10:56:02 -07:00
object-file-convert.h
object-file.c Merge branch 'jk/unleak-mmap' 2026-03-16 10:48:15 -07:00
object-file.h Merge branch 'ps/fsck-stream-from-the-right-object-instance' 2026-03-05 10:04:49 -08:00
object-name.c Merge branch 'ps/commit-list-functions-renamed' 2026-02-13 13:39:25 -08:00
object-name.h
object.c Merge branch 'ps/fsck-stream-from-the-right-object-instance' 2026-03-05 10:04:49 -08:00
object.h Merge branch 'ps/receive-pack-shallow-optim' 2026-03-02 17:06:53 -08:00
odb.c odb/source: make `write_alternate()` function pluggable 2026-03-05 11:45:17 -08:00
odb.h odb/source: make `read_alternates()` function pluggable 2026-03-05 11:45:16 -08:00
oid-array.c
oid-array.h
oidmap.c oidmap: make entry cleanup explicit in oidmap_clear 2026-03-05 11:16:18 -08:00
oidmap.h oidmap: make entry cleanup explicit in oidmap_clear 2026-03-05 11:16:18 -08:00
oidset.c oidset: introduce `oidset_equal()` 2025-11-25 12:15:59 -08:00
oidset.h oidset: introduce `oidset_equal()` 2025-11-25 12:15:59 -08:00
oidtree.c hash: use uint32_t for object_id algorithm 2026-02-07 17:41:01 -08:00
oidtree.h
pack-bitmap-write.c Merge branch 'ps/commit-list-functions-renamed' 2026-02-13 13:39:25 -08:00
pack-bitmap.c refs: replace `refs_for_each_ref_in()` 2026-02-23 13:21:18 -08:00
pack-bitmap.h refs: rename `each_ref_fn` 2026-02-23 13:21:18 -08:00
pack-check.c pack-check: fix verification of large objects 2026-02-23 13:19:00 -08:00
pack-mtimes.c
pack-mtimes.h
pack-objects.c Merge branch 'ps/remove-packfile-store-get-packs' 2025-10-30 08:00:19 -07:00
pack-objects.h
pack-refs.c refs: rename 'pack_refs_opts' to 'refs_optimize_opts' 2025-11-04 07:35:12 -08:00
pack-refs.h builtin/pack-refs: factor out core logic into a shared library 2025-09-19 10:02:55 -07:00
pack-revindex.c Merge branch 'jk/unleak-mmap' 2026-03-16 10:48:15 -07:00
pack-revindex.h midx: fix `BUG()` when getting preferred pack without a reverse index 2025-12-11 12:09:58 +09:00
pack-write.c
pack.h
packfile.c Merge branch 'ps/odb-sources' 2026-03-12 14:09:07 -07:00
packfile.h Merge branch 'ps/odb-sources' 2026-03-12 14:09:07 -07:00
pager.c
pager.h
parallel-checkout.c streaming: move into object database subsystem 2025-11-23 12:56:46 -08:00
parallel-checkout.h
parse-options-cb.c color: use git_colorbool enum type to store colorbools 2025-09-16 17:59:53 -07:00
parse-options.c Merge branch 'rs/parse-options-duplicated-long-options' 2026-03-10 14:23:19 -07:00
parse-options.h
parse.c
parse.h
patch-delta.c
patch-ids.c patch-ids: document intentional const-casting in patch_id_neq() 2026-03-09 12:45:19 -07:00
patch-ids.h
path-walk.c path-walk: use repo_parse_tree_gently() 2026-01-09 18:36:17 -08:00
path-walk.h
path.c Merge branch 'kj/path-micro-code-cleanup' 2026-03-12 10:56:02 -07:00
path.h path: remove repository argument from worktree_git_path() 2026-02-19 11:03:24 -08:00
pathspec.c
pathspec.h
pkt-line.c global: constify some pointers that are not written to 2026-02-05 17:52:49 -08:00
pkt-line.h
preload-index.c
preload-index.h
pretty.c mailmap: stop using the_repository 2026-02-20 08:13:58 -08:00
pretty.h color: use git_colorbool enum type to store colorbools 2025-09-16 17:59:53 -07:00
prio-queue.c
prio-queue.h
progress.c progress: pay attention to (customized) delay time 2025-08-25 15:50:17 -07:00
progress.h
promisor-remote.c promisor-remote: change promisor_remote_reply()'s signature 2026-02-17 11:46:41 -08:00
promisor-remote.h promisor-remote: change promisor_remote_reply()'s signature 2026-02-17 11:46:41 -08:00
prompt.c
prompt.h
protocol-caps.c remove duplicate includes 2026-02-08 15:03:06 -08:00
protocol-caps.h
protocol.c Merge branch 'jc/string-list-split' 2025-08-21 13:46:59 -07:00
protocol.h
prune-packed.c
prune-packed.h
pseudo-merge.c refs: expose peeled object ID via the iterator 2025-11-04 07:32:25 -08:00
pseudo-merge.h
quote.c
quote.h
range-diff.c range-diff: rename other_arg to log_arg 2025-09-25 11:34:11 -07:00
range-diff.h range-diff: rename other_arg to log_arg 2025-09-25 11:34:11 -07:00
reachable.c reachable: convert to use `odb_for_each_object()` 2026-01-26 08:26:08 -08:00
reachable.h
read-cache-ll.h read-cache: update add_files_to_cache take param ignored_too 2026-02-06 09:43:26 -08:00
read-cache.c Merge branch 'cs/add-skip-submodule-ignore-all' 2026-03-09 14:36:55 -07:00
read-cache.h
rebase-interactive.c
rebase-interactive.h
rebase.c
rebase.h
ref-filter.c Merge branch 'ps/refs-for-each' 2026-03-09 14:36:55 -07:00
ref-filter.h Merge branch 'jt/repo-structure' 2025-11-04 07:48:07 -08:00
reflog-walk.c global: constify some pointers that are not written to 2026-02-05 17:52:49 -08:00
reflog-walk.h
reflog.c commit: rename `free_commit_list()` to conform to coding guidelines 2026-01-15 05:32:31 -08:00
reflog.h Merge branch 'ps/remote-rename-fix' 2025-08-21 13:46:58 -07:00
refs.c Merge branch 'ar/config-hooks' 2026-03-10 14:23:18 -07:00
refs.h Merge branch 'ps/refs-for-each' 2026-03-09 14:36:55 -07:00
refspec.c
refspec.h
remote-curl.c remote-curl: use auth for probe_rpc() requests too 2026-01-14 09:44:30 -08:00
remote.c remote: add remote.*.negotiationRestrict config 2026-05-20 11:33:24 +09:00
remote.h remote: add remote.*.negotiationRestrict config 2026-05-20 11:33:24 +09:00
repack-cruft.c packfile: introduce macro to iterate through packs 2025-10-16 14:42:39 -07:00
repack-filtered.c repack: move `write_filtered_pack()` out of the builtin 2025-10-16 10:08:57 -07:00
repack-geometry.c builtin/repack: handle promisor packs with geometric repacking 2026-01-14 06:29:24 -08:00
repack-midx.c pack-bitmap: deduplicate logic to iterate over preferred bitmap tips 2026-02-19 10:41:18 -08:00
repack-promisor.c Merge branch 'ps/odb-for-each-object' 2026-03-02 17:06:50 -08:00
repack.c packfile: introduce macro to iterate through packs 2025-10-16 14:42:39 -07:00
repack.h builtin/repack: handle promisor packs with geometric repacking 2026-01-14 06:29:24 -08:00
replace-object.c refs: introduce wrapper struct for `each_ref_fn` 2025-11-04 07:32:24 -08:00
replace-object.h
replay.c replay: prevent the_repository from coming back 2026-02-21 18:37:25 -08:00
replay.h builtin/replay: move core logic into "libgit.a" 2026-01-13 05:41:16 -08:00
repo-settings.c environment: move access to core.maxTreeDepth into repo settings 2026-01-09 18:36:16 -08:00
repo-settings.h environment: move access to core.maxTreeDepth into repo settings 2026-01-09 18:36:16 -08:00
repository.c Merge branch 'bc/sha1-256-interop-02' 2026-03-12 10:56:02 -07:00
repository.h Merge branch 'bc/sha1-256-interop-02' 2026-03-12 10:56:02 -07:00
rerere.c
rerere.h
reset.c cocci: convert parse_tree functions to repo_ variants 2026-01-09 18:36:18 -08:00
reset.h
resolve-undo.c
resolve-undo.h
revision.c Merge branch 'ps/refs-for-each' 2026-03-09 14:36:55 -07:00
revision.h revision: add --maximal-only option 2026-01-22 10:58:14 -08:00
run-command.c Merge branch 'bk/run-command-wo-the-repository' 2026-03-19 09:54:56 -07:00
run-command.h Merge branch 'bk/run-command-wo-the-repository' 2026-03-19 09:54:56 -07:00
sane-ctype.h
scalar.c global: constify some pointers that are not written to 2026-02-05 17:52:49 -08:00
send-pack.c fetch: add --negotiation-restrict option 2026-05-20 11:33:23 +09:00
send-pack.h
sequencer.c Merge branch 'lc/rebase-trailer' 2026-03-19 09:54:56 -07:00
sequencer.h rebase: support --trailer 2026-03-06 13:02:20 -08:00
serve.c hash: use uint32_t for object_id algorithm 2026-02-07 17:41:01 -08:00
serve.h
server-info.c Merge branch 'ps/ref-peeled-tags' 2025-11-19 10:55:39 -08:00
server-info.h
setup.c Merge branch 'ty/setup-error-tightening' 2026-03-16 10:48:14 -07:00
setup.h Merge branch 'ty/setup-error-tightening' 2026-03-16 10:48:14 -07:00
sh-i18n--envsubst.c
sha1dc_git.c
sha1dc_git.h
shallow.c Merge branch 'sp/shallow-deepen-relative-fix' 2026-03-04 10:52:59 -08:00
shallow.h Merge branch 'sp/shallow-deepen-relative-fix' 2026-03-04 10:52:59 -08:00
shared.mak Makefile: introduce infrastructure to build internal Rust library 2025-10-02 09:32:31 -07:00
shell.c
shortlog.h
sideband.c color: use git_colorbool enum type to store colorbools 2025-09-16 17:59:53 -07:00
sideband.h
sigchain.c
sigchain.h
simple-ipc.h
sparse-index.c environment: stop using core.sparseCheckout globally 2026-02-26 07:22:51 -08:00
sparse-index.h
split-index.c
split-index.h
stable-qsort.c
statinfo.c
statinfo.h
strbuf.c global: constify some pointers that are not written to 2026-02-05 17:52:49 -08:00
strbuf.h builtin/repo: add inflated object info to structure table 2025-12-18 09:02:31 +09:00
string-list.c Merge branch 'cf/c23-const-preserving-strchr-updates-0' 2026-02-13 13:39:25 -08:00
string-list.h string-list: add string_list_sort_u() that mimics "sort -u" 2026-01-29 09:32:50 -08:00
strmap.c
strmap.h
strvec.c
strvec.h
sub-process.c
sub-process.h
submodule-config.c
submodule-config.h
submodule.c Merge branch 'ty/setup-error-tightening' 2026-03-16 10:48:14 -07:00
submodule.h
symlinks.c symlinks: use unsigned int for flags 2026-02-20 15:03:42 -08:00
symlinks.h symlinks: use unsigned int for flags 2026-02-20 15:03:42 -08:00
tag.c tag: stop using the_repository 2025-12-29 22:02:54 +09:00
tag.h tag: support arbitrary repositories in parse_tag() 2025-12-29 22:02:54 +09:00
tar.h
tempfile.c
tempfile.h
thread-utils.c
thread-utils.h
tmp-objdir.c odb: move reparenting logic into respective subsystems 2026-03-05 11:45:15 -08:00
tmp-objdir.h odb: move reparenting logic into respective subsystems 2026-03-05 11:45:15 -08:00
trace.c
trace.h
trace2.c
trace2.h
trailer.c commit, tag: parse --trailer with OPT_STRVEC 2026-03-06 13:02:20 -08:00
trailer.h commit, tag: parse --trailer with OPT_STRVEC 2026-03-06 13:02:20 -08:00
transport-helper.c transport: rename negotiation_tips 2026-05-20 11:33:23 +09:00
transport-internal.h
transport.c fetch: add --negotiation-include option for negotiation 2026-05-20 11:33:24 +09:00
transport.h fetch: add --negotiation-include option for negotiation 2026-05-20 11:33:24 +09:00
tree-diff.c tree-diff: remove the usage of the_hash_algo global 2026-02-20 10:21:11 -08:00
tree-walk.c environment: move access to core.maxTreeDepth into repo settings 2026-01-09 18:36:16 -08:00
tree-walk.h
tree.c tree: stop using the_repository 2026-01-09 18:36:17 -08:00
tree.h tree: stop using the_repository 2026-01-09 18:36:17 -08:00
unicode-width.h unicode: update the width tables to Unicode 17 2025-10-21 10:03:00 -07:00
unimplemented.sh
unix-socket.c
unix-socket.h
unix-stream-server.c
unix-stream-server.h
unpack-trees.c environment: stop using core.sparseCheckout globally 2026-02-26 07:22:51 -08:00
unpack-trees.h
upload-pack.c Merge branch 'ps/refs-for-each' 2026-03-09 14:36:55 -07:00
upload-pack.h
url.c submodule: fix case-folding gitdir filesystem collisions 2026-01-12 11:56:56 -08:00
url.h submodule: fix case-folding gitdir filesystem collisions 2026-01-12 11:56:56 -08:00
urlmatch.c
urlmatch.h
usage.c Merge branch 'kh/you-still-use-whatchanged-fix' 2025-10-02 12:26:12 -07:00
userdiff.c
userdiff.h
utf8.c utf8.c: prepare workaround for iconv under macOS 14/15 2026-01-12 12:00:04 -08:00
utf8.h
varint.c varint: use explicit width for integers 2025-10-02 09:32:32 -07:00
varint.h varint: use explicit width for integers 2025-10-02 09:32:32 -07:00
version-def.h.in
version.c version: stop using the_repository 2026-02-08 15:16:49 -08:00
version.h version: stop using the_repository 2026-02-08 15:16:49 -08:00
versioncmp.c
versioncmp.h
walker.c cocci: convert parse_tree functions to repo_ variants 2026-01-09 18:36:18 -08:00
walker.h
wildmatch.c
wildmatch.h
worktree.c Merge branch 'dd/list-objects-filter-options-wo-strbuf-split' 2026-03-19 09:54:55 -07:00
worktree.h Merge branch 'dd/list-objects-filter-options-wo-strbuf-split' 2026-03-19 09:54:55 -07:00
wrapper.c global: constify some pointers that are not written to 2026-02-05 17:52:49 -08:00
wrapper.h wrapper: add git_mkdtemp() 2025-12-07 07:28:11 +09:00
write-or-die.c
write-or-die.h write-or-die: add an fsync component for the object map 2026-02-07 17:41:02 -08:00
ws.c apply: check and fix incomplete lines 2025-11-12 14:04:04 -08:00
ws.h whitespace: allocate a few more bits and define WS_INCOMPLETE_LINE 2025-11-12 14:04:04 -08:00
wt-status.c Merge branch 'sp/wt-status-wo-the-repository' 2026-03-16 10:48:14 -07:00
wt-status.h wt-status: provide function to expose status for trees 2026-01-13 05:41:16 -08:00
xdiff-interface.c xdiff-interface: stop using the_repository 2026-02-10 08:16:14 -08:00
xdiff-interface.h xdiff-interface: stop using the_repository 2026-02-10 08:16:14 -08:00

README.md

Build status

Git - fast, scalable, distributed revision control system

Git is a fast, scalable, distributed revision control system with an unusually rich command set that provides both high-level operations and full access to internals.

Git is an Open Source project covered by the GNU General Public License version 2 (some parts of it are under different licenses, compatible with the GPLv2). It was originally written by Linus Torvalds with help of a group of hackers around the net.

Please read the file INSTALL for installation instructions.

Many Git online resources are accessible from https://git-scm.com/ including full documentation and Git related tools.

See Documentation/gittutorial.adoc to get started, then see Documentation/giteveryday.adoc for a useful minimum set of commands, and Documentation/git-<commandname>.adoc for documentation of each command. If git has been correctly installed, then the tutorial can also be read with man gittutorial or git help tutorial, and the documentation of each command with man git-<commandname> or git help <commandname>.

CVS users may also want to read Documentation/gitcvs-migration.adoc (man gitcvs-migration or git help cvs-migration if git is installed).

The user discussion and development of Git take place on the Git mailing list -- everyone is welcome to post bug reports, feature requests, comments and patches to git@vger.kernel.org (read Documentation/SubmittingPatches for instructions on patch submission and Documentation/CodingGuidelines).

Those wishing to help with error message, usage and informational message string translations (localization l10) should see po/README.md (a po file is a Portable Object file that holds the translations).

To subscribe to the list, send an email to git+subscribe@vger.kernel.org (see https://subspace.kernel.org/subscribing.html for details). The mailing list archives are available at https://lore.kernel.org/git/, https://marc.info/?l=git and other archival sites.

Issues which are security relevant should be disclosed privately to the Git Security mailing list git-security@googlegroups.com.

The maintainer frequently sends the "What's cooking" reports that list the current status of various development topics to the mailing list. The discussion following them give a good reference for project status, development direction and remaining tasks.

The name "git" was given by Linus Torvalds when he wrote the very first version. He described the tool as "the stupid content tracker" and the name as (depending on your mood):

  • random three-letter combination that is pronounceable, and not actually used by any common UNIX command. The fact that it is a mispronunciation of "get" may or may not be relevant.
  • stupid. contemptible and despicable. simple. Take your pick from the dictionary of slang.
  • "global information tracker": you're in a good mood, and it actually works for you. Angels sing, and a light suddenly fills the room.
  • "goddamn idiotic truckload of sh*t": when it breaks