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.
 
 
 
 
 
 
Junio C Hamano 6d56d4c7dc Merge branch 'ds/blame-on-bloom' 5 years ago
.github ci: let GitHub Actions upload failed tests' directories 5 years ago
Documentation Merge branch 'gs/commit-graph-path-filter' 5 years ago
block-sha1
builtin Merge branch 'ds/blame-on-bloom' 5 years ago
ci Merge branch 'gs/commit-graph-path-filter' 5 years ago
compat Merge branch 'js/mingw-isilon-nfs' 5 years ago
contrib Merge branch 'en/fill-directory-exponential' 5 years ago
ewah
git-gui
gitk-git
gitweb
mergetools
negotiator
perl
po
ppc
refs
sha1collisiondetection@855827c583
sha1dc
sha256
t Merge branch 'ds/blame-on-bloom' 5 years ago
templates
trace2
vcs-svn
xdiff
.cirrus.yml
.clang-format
.editorconfig
.gitattributes
.gitignore
.gitmodules
.mailmap
.travis.yml ci: fix the `jobname` of the `GETTEXT_POISON` job 5 years ago
.tsan-suppressions
CODE_OF_CONDUCT.md
COPYING
GIT-VERSION-GEN Git 2.26.2 5 years ago
INSTALL
LGPL-2.1
Makefile Merge branch 'gs/commit-graph-path-filter' 5 years ago
README.md ci: retire the Azure Pipelines definition 5 years ago
RelNotes Git 2.26.2 5 years ago
abspath.c
aclocal.m4
add-interactive.c interactive: refactor code asking the user for interactive input 5 years ago
add-interactive.h
add-patch.c interactive: refactor code asking the user for interactive input 5 years ago
advice.c
advice.h
alias.c
alias.h
alloc.c
alloc.h
apply.c
apply.h
archive-tar.c parse_config_key(): return subsection len as size_t 5 years ago
archive-zip.c
archive.c
archive.h
argv-array.c
argv-array.h
attr.c
attr.h
banned.h
base85.c
bisect.c
bisect.h
blame.c blame: drop unused parameter from maybe_changed_path 5 years ago
blame.h blame: use changed-path Bloom filters 5 years ago
blob.c
blob.h
bloom.c bloom: ignore renames when computing changed paths 5 years ago
bloom.h revision.c: use Bloom filters to speed up path based revision walks 5 years ago
branch.c merge: teach --autostash option 5 years ago
branch.h
builtin.h
bulk-checkin.c
bulk-checkin.h
bundle.c
bundle.h
cache-tree.c
cache-tree.h
cache.h Merge branch 'jk/oid-array-cleanups' 5 years ago
chdir-notify.c
chdir-notify.h
check-builtins.sh
check_bindir
checkout.c
checkout.h
color.c
color.h
column.c
column.h
combine-diff.c
command-list.txt
commit-graph.c Merge branch 'ds/blame-on-bloom' 5 years ago
commit-graph.h Merge branch 'ds/blame-on-bloom' 5 years ago
commit-reach.c
commit-reach.h
commit-slab-decl.h
commit-slab-impl.h
commit-slab.h
commit.c
commit.h shallow.c: use '{commit,rollback}_shallow_file' 5 years ago
common-main.c
config.c config: reject parsing of files over INT_MAX 5 years ago
config.h git_config_parse_key(): return baselen as size_t 5 years ago
config.mak.dev
config.mak.in
config.mak.uname config.mak.uname: Define FREAD_READS_DIRECTORIES for GNU/Hurd 5 years ago
configure.ac
connect.c
connect.h
connected.c Merge branch 'jt/connectivity-check-optim-in-partial-clone' 5 years ago
connected.h
convert.c parse_config_key(): return subsection len as size_t 5 years ago
convert.h
copy.c
credential-cache--daemon.c
credential-cache.c
credential-store.c
credential.c Merge branch 'jk/credential-parsing-end-of-host-in-URL' 5 years ago
credential.h
csum-file.c
csum-file.h
ctype.c
daemon.c
date.c
decorate.c
decorate.h
delta-islands.c
delta-islands.h
delta.h
detect-compiler
diff-delta.c
diff-lib.c
diff-no-index.c
diff.c Merge branch 'jt/avoid-prefetch-when-able-in-diff' 5 years ago
diff.h
diffcore-break.c diff: restrict when prefetching occurs 5 years ago
diffcore-delta.c
diffcore-order.c
diffcore-pickaxe.c
diffcore-rename.c diff: restrict when prefetching occurs 5 years ago
diffcore.h diff: restrict when prefetching occurs 5 years ago
dir-iterator.c
dir-iterator.h
dir.c Merge branch 'en/fill-directory-exponential' 5 years ago
dir.h
editor.c
entry.c
environment.c
exec-cmd.c
exec-cmd.h
fast-import.c Merge branch 'jk/fast-import-use-hashmap' 5 years ago
fetch-negotiator.c
fetch-negotiator.h
fetch-pack.c Merge branch 'tb/reset-shallow' 5 years ago
fetch-pack.h
fmt-merge-msg.c Merge branch 'dl/libify-a-few' 5 years ago
fmt-merge-msg.h
fsck.c Merge branch 'jk/config-use-size-t' 5 years ago
fsck.h
fsmonitor.c
fsmonitor.h
fuzz-commit-graph.c commit-graph: close descriptors after mmap 5 years ago
fuzz-pack-headers.c
fuzz-pack-idx.c
generate-cmdlist.sh
gettext.c
gettext.h
git-add--interactive.perl
git-archimport.perl
git-bisect.sh
git-compat-util.h
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 Merge branch 'bk/p4-pre-edit-changelist' 5 years ago
git-parse-remote.sh
git-quiltimport.sh
git-rebase--preserve-merges.sh
git-request-pull.sh
git-send-email.perl
git-sh-i18n.sh
git-sh-setup.sh
git-submodule.sh Merge branch 'lx/submodule-clear-variables' 5 years ago
git-svn.perl
git-web--browse.sh
git.c Merge branch 'js/trace2-env-vars' 5 years ago
git.rc
gpg-interface.c
gpg-interface.h
graph.c
graph.h
grep.c
grep.h
hash.h
hashmap.c
hashmap.h
help.c
help.h
hex.c
http-backend.c
http-fetch.c
http-push.c
http-walker.c
http.c Git 2.26.2 5 years ago
http.h
ident.c
imap-send.c
interdiff.c
interdiff.h
iterator.h
json-writer.c
json-writer.h
khash.h
kwset.c
kwset.h
levenshtein.c
levenshtein.h
line-log.c diff: make diff_populate_filespec_options struct 5 years ago
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 parse_config_key(): return subsection len as size_t 5 years ago
ll-merge.h
lockfile.c
lockfile.h
log-tree.c Merge branch 'ds/log-exclude-decoration-config' 5 years ago
log-tree.h log: add log.excludeDecoration config option 5 years ago
ls-refs.c
ls-refs.h
mailinfo.c mailinfo: disallow NUL character in mail's header 5 years ago
mailinfo.h
mailmap.c
mailmap.h
match-trees.c
mem-pool.c
mem-pool.h
merge-blobs.c
merge-blobs.h
merge-recursive.c
merge-recursive.h
merge.c
mergesort.c
mergesort.h
midx.c
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
notes.h
object-store.h
object.c
object.h revision: --show-pulls adds helpful merges 5 years ago
oid-array.c
oid-array.h
oidmap.c
oidmap.h
oidset.c oidset: introduce 'oidset_size' 5 years ago
oidset.h Merge branch 'tb/commit-graph-split-strategy' 5 years ago
pack-bitmap-write.c
pack-bitmap.c
pack-bitmap.h
pack-check.c
pack-objects.c
pack-objects.h
pack-revindex.c
pack-revindex.h
pack-write.c
pack.h
packfile.c
packfile.h
pager.c
parse-options-cb.c
parse-options.c
parse-options.h merge: teach --autostash option 5 years ago
patch-delta.c
patch-ids.c
patch-ids.h
path.c Merge branch 'dl/merge-autostash' 5 years ago
path.h merge: teach --autostash option 5 years ago
pathspec.c
pathspec.h
pkt-line.c
pkt-line.h
preload-index.c
pretty.c format-patch: teach --no-encode-email-headers 5 years ago
pretty.h format-patch: teach --no-encode-email-headers 5 years ago
prio-queue.c
prio-queue.h
progress.c
progress.h
promisor-remote.c Merge branch 'jt/avoid-prefetch-when-able-in-diff' 5 years ago
promisor-remote.h promisor-remote: accept 0 as oid_nr in function 5 years ago
prompt.c interactive: explicitly `fflush` stdout before expecting input 5 years ago
prompt.h interactive: refactor code asking the user for interactive input 5 years ago
protocol.c Revert "fetch: default to protocol version 2" 5 years ago
protocol.h
prune-packed.c
prune-packed.h
quote.c
quote.h
range-diff.c range-diff: avoid negative string precision 5 years ago
range-diff.h
reachable.c
reachable.h
read-cache.c
rebase-interactive.c
rebase-interactive.h
rebase.c
rebase.h
ref-filter.c
ref-filter.h
reflog-walk.c
reflog-walk.h
refs.c Merge branch 'ds/log-exclude-decoration-config' 5 years ago
refs.h log-tree: make ref_filter_match() a helper method 5 years ago
refspec.c
refspec.h
remote-curl.c
remote-testsvn.c
remote.c parse_config_key(): return subsection len as size_t 5 years ago
remote.h
replace-object.c
replace-object.h
repo-settings.c
repository.c
repository.h Merge branch 'jc/missing-ref-store-fix' 5 years ago
rerere.c
rerere.h
reset.c Merge branch 'dl/merge-autostash' 5 years ago
reset.h reset: extract reset_head() from rebase 5 years ago
resolve-undo.c
resolve-undo.h
revision.c Merge branch 'ds/blame-on-bloom' 5 years ago
revision.h Merge branch 'gs/commit-graph-path-filter' 5 years ago
run-command.c
run-command.h
send-pack.c Merge branch 'jx/atomic-push' 5 years ago
send-pack.h
sequencer.c Merge branch 'dl/merge-autostash' 5 years ago
sequencer.h Merge branch 'dl/merge-autostash' 5 years ago
serve.c
serve.h
server-info.c
setup.c
sh-i18n--envsubst.c
sha1-file.c Merge branch 'lr/freshen-file-fix' 5 years ago
sha1-lookup.c
sha1-lookup.h
sha1-name.c Merge branch 'jc/missing-ref-store-fix' 5 years ago
sha1dc_git.c
sha1dc_git.h
shallow.c Merge branch 'tb/reset-shallow' 5 years ago
shell.c interactive: refactor code asking the user for interactive input 5 years ago
shortlog.h
sideband.c
sideband.h
sigchain.c
sigchain.h
split-index.c
split-index.h
stable-qsort.c
strbuf.c
strbuf.h
streaming.c
streaming.h
string-list.c
string-list.h
sub-process.c
sub-process.h
submodule-config.c parse_config_key(): return subsection len as size_t 5 years ago
submodule-config.h
submodule.c Merge branch 'jk/oid-array-cleanups' 5 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-helper: new method reject_atomic_push() 5 years ago
transport-internal.h
transport.c Merge branch 'jx/atomic-push' 5 years ago
transport.h transport-helper: new method reject_atomic_push() 5 years ago
tree-diff.c
tree-walk.c
tree-walk.h
tree.c
tree.h
unicode-width.h
unimplemented.sh
unix-socket.c
unix-socket.h
unpack-trees.c Merge branch 'en/sparse-checkout' 5 years ago
unpack-trees.h Merge branch 'en/sparse-checkout' 5 years ago
upload-pack.c
upload-pack.h
url.c
url.h
urlmatch.c
urlmatch.h
usage.c
userdiff.c parse_config_key(): return subsection len as size_t 5 years ago
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 'dl/wrapper-fix-indentation' 5 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). To subscribe to the list, send an email with just "subscribe git" in the body to majordomo@vger.kernel.org. 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