You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
Elijah Newren 71a146dc70 diff: fix filtering of additional headers under --remerge-diff 3 years ago
.github ci: update 'static-analysis' to Ubuntu 22.04 3 years ago
Documentation Git 2.37.3 3 years ago
block-sha1
builtin Merge branch 'jk/unused-fixes' 3 years ago
ci CI: use "GIT_TEST_SANITIZE_LEAK_LOG=true" in linux-leaks 3 years ago
compat Merge branch 'js/safe-directory-plus' into maint 3 years ago
contrib Merge branch 'jd/prompt-show-conflict' 3 years ago
ewah
git-gui
gitk-git
gitweb Merge branch 'jr/gitweb-title-shortening' 3 years ago
mergetools mergetools: vimdiff: simplify tabfirst 3 years ago
negotiator
perl
po
ppc
refs
reftable reftable: drop unused parameter from reader_seek_linear() 3 years ago
sha1collisiondetection@855827c583
sha1dc
sha256 sha256: add support for Nettle 3 years ago
t diff: fix filtering of additional headers under --remerge-diff 3 years ago
templates
trace2 tr2: shows scope unconditionally in addition to key-value pair 3 years ago
xdiff xdiff: drop unused mmfile parameters from xdl_do_patience_diff() 3 years ago
.cirrus.yml
.clang-format
.editorconfig
.gitattributes
.gitignore builtin/diagnose.c: create 'git diagnose' builtin 3 years ago
.gitmodules
.mailmap
.tsan-suppressions
CODE_OF_CONDUCT.md
COPYING
GIT-VERSION-GEN Git 2.37.3 3 years ago
INSTALL
LGPL-2.1
Makefile Merge branch 'mt/rot13-in-c' 3 years ago
README.md
RelNotes A handful more topics from the 'master' front for 2.37.3 3 years ago
SECURITY.md
abspath.c
aclocal.m4
add-interactive.c
add-interactive.h
add-patch.c
advice.c
advice.h
alias.c
alias.h
alloc.c
alloc.h
apply.c
apply.h
archive-tar.c
archive-zip.c
archive.c
archive.h
attr.c match_pathname(): drop unused "flags" parameter 3 years ago
attr.h
banned.h
base85.c
bisect.c revisions API: don't leak memory on argv elements that need free()-ing 3 years ago
bisect.h
blame.c Merge branch 'rs/mergesort' 3 years ago
blame.h
blob.c
blob.h
bloom.c commit-graph: fix corrupt upgrade from generation v1 to v2 3 years ago
bloom.h
branch.c branch: consider refs under 'update-refs' 3 years ago
branch.h Merge branch 'ds/branch-checked-out' into ds/rebase-update-ref 3 years ago
builtin.h builtin/diagnose.c: create 'git diagnose' builtin 3 years ago
bulk-checkin.c t5351: avoid relying on `core.fsyncMethod = batch` to be supported 3 years ago
bulk-checkin.h
bundle.c
bundle.h
cache-tree.c verify_one_sparse(): drop unused parameters 3 years ago
cache-tree.h
cache.h Merge branch 'ds/decorate-filter-tweak' 3 years ago
cbtree.c
cbtree.h
chdir-notify.c
chdir-notify.h
check-builtins.sh
checkout.c
checkout.h
chunk-format.c
chunk-format.h
color.c
color.h
column.c
column.h
combine-diff.c Merge branch 'rs/combine-diff-with-incompatible-options' into maint 3 years ago
command-list.txt docs: move http-protocol docs to man section 5 3 years ago
commit-graph.c Merge branch 'tb/commit-graph-genv2-upgrade-fix' into maint 3 years ago
commit-graph.h Merge branch 'tb/commit-graph-genv2-upgrade-fix' 3 years ago
commit-reach.c
commit-reach.h
commit-slab-decl.h
commit-slab-impl.h
commit-slab.h
commit.c Merge branch 'rs/mergesort' 3 years ago
commit.h
common-main.c
config.c config.c: NULL check when reading protected config 3 years ago
config.h config: learn `git_protected_config()` 3 years ago
config.mak.dev config.mak.dev: squelch -Wno-missing-braces for older gcc 3 years ago
config.mak.in
config.mak.uname mingw: remove unneeded `NO_CURL` directive 3 years ago
configure.ac
connect.c
connect.h
connected.c
connected.h
convert.c
convert.h checkout: fix two bugs on the final count of updated entries 3 years ago
copy.c
credential.c
credential.h
csum-file.c
csum-file.h
ctype.c
daemon.c daemon: clarify directory arguments 3 years ago
date.c
date.h
decorate.c
decorate.h
delta-islands.c
delta-islands.h
delta.h
detect-compiler
diagnose.c builtin/diagnose.c: add '--mode' option 3 years ago
diagnose.h builtin/diagnose.c: add '--mode' option 3 years ago
diff-delta.c
diff-lib.c oneway_diff: handle removed sparse directories 3 years ago
diff-merges.c
diff-merges.h
diff-no-index.c
diff.c diff: fix filtering of additional headers under --remerge-diff 3 years ago
diff.h
diffcore-break.c
diffcore-delta.c
diffcore-order.c
diffcore-pickaxe.c
diffcore-rename.c
diffcore-rotate.c
diffcore.h
dir-iterator.c
dir-iterator.h
dir.c match_pathname(): drop unused "flags" parameter 3 years ago
dir.h match_pathname(): drop unused "flags" parameter 3 years ago
editor.c
entry.c checkout: fix two bugs on the final count of updated entries 3 years ago
entry.h checkout: fix two bugs on the final count of updated entries 3 years ago
environment.c refs: use ref_namespaces for replace refs base 3 years ago
environment.h
exec-cmd.c
exec-cmd.h
fetch-negotiator.c
fetch-negotiator.h
fetch-pack.c fetch-pack: add tracing for negotiation rounds 3 years ago
fetch-pack.h
fmt-merge-msg.c
fmt-merge-msg.h
fsck.c fsck: actually detect bad file modes in trees 3 years ago
fsck.h fsck: downgrade tree badFilemode to "info" 3 years ago
fsmonitor--daemon.h
fsmonitor-ipc.c
fsmonitor-ipc.h
fsmonitor-settings.c
fsmonitor-settings.h
fsmonitor.c
fsmonitor.h
fuzz-commit-graph.c commit-graph: pass repo_settings instead of repository 3 years ago
fuzz-pack-headers.c
fuzz-pack-idx.c
generate-cmdlist.sh
generate-configlist.sh
generate-hooklist.sh
gettext.c
gettext.h
git-add--interactive.perl
git-archimport.perl
git-bisect.sh
git-compat-util.h Merge branch 'vd/scalar-generalize-diagnose' 3 years ago
git-curl-compat.h
git-cvsexportcommit.perl
git-cvsimport.perl
git-cvsserver.perl git-cvsserver: clarify directory list 3 years ago
git-difftool--helper.sh
git-filter-branch.sh
git-instaweb.sh
git-merge-octopus.sh
git-merge-one-file.sh
git-merge-resolve.sh merge-resolve: abort if index does not match HEAD 3 years ago
git-mergetool--lib.sh
git-mergetool.sh
git-p4.py Merge branch 'kk/p4-client-name-encoding-fix' into maint 3 years ago
git-quiltimport.sh
git-request-pull.sh
git-send-email.perl
git-sh-i18n.sh
git-sh-setup.sh
git-submodule.sh
git-svn.perl
git-web--browse.sh
git.c builtin/diagnose.c: create 'git diagnose' builtin 3 years ago
git.rc
gpg-interface.c gpg-interface: add function for converting trust level to string 3 years ago
gpg-interface.h gpg-interface: add function for converting trust level to string 3 years ago
graph.c
graph.h
grep.c
grep.h
hash-lookup.c
hash-lookup.h
hash.h sha256: add support for Nettle 3 years ago
hashmap.c
hashmap.h
help.c git docs: add a category for file formats, protocols and interfaces 3 years ago
help.h git docs: add a category for file formats, protocols and interfaces 3 years ago
hex.c
hook.c Merge branch 'ab/hooks-regression-fix' into maint 3 years ago
hook.h
http-backend.c
http-fetch.c
http-push.c
http-walker.c
http.c Merge branch 'll/curl-accept-language' 3 years ago
http.h remote-curl: send Accept-Language header to server 3 years ago
ident.c ident: rename commit_rewrite_person() to apply_mailmap_to_header() 3 years ago
imap-send.c
iterator.h
json-writer.c
json-writer.h
khash.h
kwset.c
kwset.h
levenshtein.c
levenshtein.h
line-log.c
line-log.h
line-range.c
line-range.h
linear-assignment.c
linear-assignment.h
list-objects-filter-options.c
list-objects-filter-options.h
list-objects-filter.c
list-objects-filter.h
list-objects.c
list-objects.h
list.h
ll-merge.c
ll-merge.h
lockfile.c
lockfile.h
log-tree.c Merge branch 'jk/unused-fixes' 3 years ago
log-tree.h
ls-refs.c
ls-refs.h
mailinfo.c
mailinfo.h
mailmap.c
mailmap.h
match-trees.c
mem-pool.c
mem-pool.h
merge-blobs.c
merge-blobs.h
merge-ort-wrappers.c merge-ort-wrappers: make printed message match the one from recursive 3 years ago
merge-ort-wrappers.h
merge-ort.c Merge branch 'en/ort-unused-code-removal' 3 years ago
merge-ort.h
merge-recursive.c
merge-recursive.h
merge.c
mergesort.h mergesort: remove llist_mergesort() 3 years ago
midx.c write_midx_bitmap(): drop unused refs_snapshot parameter 3 years ago
midx.h
name-hash.c
notes-cache.c
notes-cache.h
notes-merge.c
notes-merge.h
notes-utils.c
notes-utils.h
notes.c refs: add array of ref namespaces 3 years ago
notes.h
object-file.c Merge branch 'hx/unpack-streaming' 3 years ago
object-name.c
object-store.h
object.c
object.h revision: allow --ancestry-path to take an argument 3 years ago
oid-array.c
oid-array.h
oidmap.c
oidmap.h
oidset.c
oidset.h
oidtree.c
oidtree.h
pack-bitmap-write.c pack-bitmap-write: use const for hashes 3 years ago
pack-bitmap.c Merge branch 'tl/pack-bitmap-error-messages' 3 years ago
pack-bitmap.h pack-bitmap-write: use const for hashes 3 years ago
pack-check.c
pack-mtimes.c
pack-mtimes.h
pack-objects.c
pack-objects.h
pack-revindex.c
pack-revindex.h docs: move pack format docs to man section 5 3 years ago
pack-write.c
pack.h
packfile.c Merge branch 'jk/is-promisor-object-keep-tree-in-use' 3 years ago
packfile.h
pager.c
parallel-checkout.c checkout: fix two bugs on the final count of updated entries 3 years ago
parallel-checkout.h checkout: fix two bugs on the final count of updated entries 3 years ago
parse-options-cb.c
parse-options.c
parse-options.h
patch-delta.c
patch-ids.c
patch-ids.h
path.c
path.h
pathspec.c pathspec.h: move pathspec_needs_expanded_index() from reset.c to here 3 years ago
pathspec.h pathspec.h: move pathspec_needs_expanded_index() from reset.c to here 3 years ago
pkt-line.c t0021: implementation the rot13-filter.pl script in C 3 years ago
pkt-line.h Merge branch 'mt/rot13-in-c' 3 years ago
preload-index.c preload-index: fix memleak 3 years ago
pretty.c gpg-interface: add function for converting trust level to string 3 years ago
pretty.h
prio-queue.c
prio-queue.h
progress.c
progress.h
promisor-remote.c Merge branch 'sg/xcalloc-cocci-fix' 3 years ago
promisor-remote.h
prompt.c
prompt.h
protocol-caps.c
protocol-caps.h
protocol.c
protocol.h
prune-packed.c
prune-packed.h
quote.c
quote.h
range-diff.c
range-diff.h
reachable.c
reachable.h
read-cache.c Merge branch 'vd/sparse-reset-checkout-fixes' into maint 3 years ago
rebase-interactive.c sequencer: rewrite update-refs as user edits todo list 3 years ago
rebase-interactive.h
rebase.c
rebase.h
ref-filter.c ref-filter: disable save_commit_buffer while traversing 3 years ago
ref-filter.h
reflog-walk.c
reflog-walk.h
reflog.c
reflog.h
refs.c refs: use ref_namespaces for replace refs base 3 years ago
refs.h refs: add array of ref namespaces 3 years ago
refspec.c
refspec.h docs: move protocol-related docs to man section 5 3 years ago
remote-curl.c remote-curl: send Accept-Language header to server 3 years ago
remote.c Merge branch 'ab/plug-revisions-leak' 3 years ago
remote.h Merge branch 'rs/mergesort' 3 years ago
replace-object.c
replace-object.h
repo-settings.c commit-graph: pass repo_settings instead of repository 3 years ago
repository.c
repository.h commit-graph: pass repo_settings instead of repository 3 years ago
rerere.c
rerere.h
reset.c
reset.h
resolve-undo.c
resolve-undo.h
revision.c revision: allow --ancestry-path to take an argument 3 years ago
revision.h revision: allow --ancestry-path to take an argument 3 years ago
run-command.c pipe_command(): mark stdin descriptor as non-blocking 3 years ago
run-command.h
send-pack.c
send-pack.h
sequencer.c sequencer: do not translate command names 3 years ago
sequencer.h sequencer: rewrite update-refs as user edits todo list 3 years ago
serve.c
serve.h
server-info.c
setup.c Merge branch 'js/safe-directory-plus' into maint 3 years ago
sh-i18n--envsubst.c
sha1dc_git.c
sha1dc_git.h
shallow.c
shallow.h
shared.mak cocci: add a "coccicheck-test" target and test *.cocci rules 3 years ago
shell.c
shortlog.h
sideband.c
sideband.h
sigchain.c
sigchain.h
simple-ipc.h
sparse-index.c
sparse-index.h
split-index.c
split-index.h
stable-qsort.c
strbuf.c
strbuf.h
streaming.c
streaming.h
string-list.c
string-list.h
strmap.c
strmap.h
strvec.c
strvec.h
sub-process.c
sub-process.h
submodule-config.c
submodule-config.h
submodule.c Merge branch 'ab/leakfix' 3 years ago
submodule.h
symlinks.c
tag.c
tag.h
tar.h
tempfile.c
tempfile.h
thread-utils.c
thread-utils.h
tmp-objdir.c
tmp-objdir.h
trace.c
trace.h
trace2.c
trace2.h
trailer.c
trailer.h
transport-helper.c
transport-internal.h
transport.c transport.c: avoid "whitelist" 3 years ago
transport.h
tree-diff.c
tree-walk.c tree-walk: add a mechanism for getting non-canonicalized modes 3 years ago
tree-walk.h tree-walk: add a mechanism for getting non-canonicalized modes 3 years ago
tree.c
tree.h
unicode-width.h
unimplemented.sh
unix-socket.c
unix-socket.h
unix-stream-server.c
unix-stream-server.h
unpack-trees.c Merge branch 'vd/sparse-reset-checkout-fixes' into maint 3 years ago
unpack-trees.h
upload-pack.c upload-pack: fix a memory leak in create_pack_file() 3 years ago
upload-pack.h
url.c
url.h
urlmatch.c
urlmatch.h
usage.c
userdiff.c
userdiff.h
utf8.c
utf8.h
varint.c
varint.h
version.c
version.h
versioncmp.c
walker.c
walker.h
wildmatch.c
wildmatch.h
worktree.c
worktree.h
wrap-for-bin.sh
wrapper.c Merge branch 'jk/pipe-command-nonblock' 3 years ago
write-or-die.c
ws.c
wt-status.c
wt-status.h
xdiff-interface.c
xdiff-interface.h
zlib.c

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.txt to get started, then see Documentation/giteveryday.txt for a useful minimum set of commands, and Documentation/git-<commandname>.txt 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.txt (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 with just "subscribe git" in the body to majordomo@vger.kernel.org (not the Git list). The mailing list archives are available at https://lore.kernel.org/git/, http://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