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.
 
 
 
 
 
 
Jeff King ed4b804e46 test-tool: rename sha1-array to oid-array 5 years ago
.github
Documentation RelNotes/2.26.0: fix various typos 5 years ago
block-sha1
builtin oid_array: rename source file from sha1-array 5 years ago
ci Merge branch 'js/ci-windows-update' 5 years ago
compat Merge branch 'js/mingw-open-in-gdb' into maint 5 years ago
contrib Merge branch 'kk/complete-diff-color-moved' 5 years ago
ewah Merge branch 'jk/object-filter-with-bitmap' 5 years ago
git-gui Merge https://github.com/prati0100/git-gui 5 years ago
gitk-git
gitweb
mergetools
negotiator
perl
po l10n: tr.po: change file mode to 644 5 years ago
ppc
refs
sha1collisiondetection@855827c583
sha1dc
sha256
t test-tool: rename sha1-array to oid-array 5 years ago
templates
trace2
vcs-svn
xdiff
.cirrus.yml
.clang-format
.editorconfig
.gitattributes
.gitignore
.gitmodules
.mailmap Merge branch 'bc/wildcard-credential' 5 years ago
.travis.yml
.tsan-suppressions
CODE_OF_CONDUCT.md
COPYING
GIT-VERSION-GEN Git 2.26 5 years ago
INSTALL
LGPL-2.1
Makefile test-tool: rename sha1-array to oid-array 5 years ago
README.md
RelNotes Git 2.25.2 5 years ago
abspath.c
aclocal.m4
add-interactive.c Merge branch 'js/builtin-add-i-cmds' into maint 5 years ago
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
argv-array.c
argv-array.h
attr.c
attr.h
azure-pipelines.yml Azure Pipeline: switch to the latest agent pools 5 years ago
banned.h
base85.c
bisect.c oid_array: rename source file from sha1-array 5 years ago
bisect.h
blame.c
blame.h
blob.c
blob.h
branch.c
branch.h
builtin.h
bulk-checkin.c
bulk-checkin.h
bundle.c
bundle.h
cache-tree.c
cache-tree.h
cache.h oid_array: rename source file from sha1-array 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 oid_array: rename source file from sha1-array 5 years ago
command-list.txt
commit-graph.c Merge branch 'rs/commit-graph-code-simplification' 5 years ago
commit-graph.h
commit-reach.c
commit-reach.h
commit-slab-decl.h
commit-slab-impl.h
commit-slab.h
commit.c
commit.h
common-main.c
config.c Merge branch 'bw/remote-rename-update-config' 5 years ago
config.h
config.mak.dev config.mak.dev: re-enable -Wformat-zero-length 5 years ago
config.mak.in
config.mak.uname
configure.ac
connect.c oid_array: rename source file from sha1-array 5 years ago
connect.h
connected.c
connected.h
convert.c
convert.h
copy.c
credential-cache--daemon.c
credential-cache.c
credential-store.c
credential.c
credential.h Merge branch 'bc/wildcard-credential' 5 years ago
csum-file.c
csum-file.h
ctype.c
daemon.c
date.c
decorate.c
decorate.h
delta-islands.c oid_array: rename source file from sha1-array 5 years ago
delta-islands.h
delta.h
detect-compiler
diff-delta.c
diff-lib.c
diff-no-index.c
diff.c
diff.h
diffcore-break.c
diffcore-delta.c
diffcore-order.c
diffcore-pickaxe.c
diffcore-rename.c
diffcore.h
dir-iterator.c
dir-iterator.h
dir.c Merge branch 'ds/sparse-add' 5 years ago
dir.h
editor.c
entry.c
environment.c
exec-cmd.c
exec-cmd.h
fast-import.c
fetch-negotiator.c
fetch-negotiator.h
fetch-pack.c oid_array: rename source file from sha1-array 5 years ago
fetch-pack.h
fmt-merge-msg.h
fsck.c
fsck.h
fsmonitor.c
fsmonitor.h
fuzz-commit-graph.c
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-legacy-stash.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-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 'es/recursive-single-branch-clone' 5 years ago
git-svn.perl
git-web--browse.sh
git.c
git.rc
gpg-interface.c Merge branch 'hi/gpg-use-check-signature' 5 years ago
gpg-interface.h Merge branch 'hi/gpg-use-check-signature' 5 years ago
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
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
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 'hd/show-one-mergetag-fix' into maint 5 years ago
log-tree.h
ls-refs.c
ls-refs.h
mailinfo.c Merge branch 'rs/micro-cleanups' 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 branch 'en/t3433-rebase-stat-dirty-failure' into maint 5 years ago
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 Merge branch 'jh/notes-fanout-fix' into maint 5 years ago
notes.h
object-store.h oid_array: rename source file from sha1-array 5 years ago
object.c Merge branch 'jk/object-filter-with-bitmap' 5 years ago
object.h
oid-array.c oid_array: rename source file from sha1-array 5 years ago
oid-array.h oid_array: rename source file from sha1-array 5 years ago
oidmap.c
oidmap.h
oidset.c
oidset.h
pack-bitmap-write.c
pack-bitmap.c Merge branch 'jk/nth-packed-object-id' 5 years ago
pack-bitmap.h Merge branch 'jk/object-filter-with-bitmap' 5 years ago
pack-check.c pack-check: push oid lookup into loop 5 years ago
pack-objects.c pack-objects: convert oe_set_delta_ext() to use object_id 5 years ago
pack-objects.h pack-objects: convert oe_set_delta_ext() to use object_id 5 years ago
pack-revindex.c
pack-revindex.h
pack-write.c
pack.h
packfile.c packfile: drop nth_packed_object_sha1() 5 years ago
packfile.h packfile: drop nth_packed_object_sha1() 5 years ago
pager.c
parse-options-cb.c oid_array: rename source file from sha1-array 5 years ago
parse-options.c Merge branch 'pb/am-show-current-patch' 5 years ago
parse-options.h Merge branch 'pb/am-show-current-patch' 5 years ago
patch-delta.c
patch-ids.c
patch-ids.h
path.c
path.h
pathspec.c prefix_path: show gitdir if worktree unavailable 5 years ago
pathspec.h
pkt-line.c
pkt-line.h
preload-index.c
pretty.c
pretty.h
prio-queue.c
prio-queue.h
progress.c
progress.h
promisor-remote.c
promisor-remote.h
prompt.c
prompt.h
protocol.c
protocol.h
quote.c
quote.h
range-diff.c
range-diff.h
reachable.c
reachable.h
read-cache.c
rebase-interactive.c Merge branch 'rt/format-zero-length-fix' 5 years ago
rebase-interactive.h Merge branch 'en/rebase-backend' 5 years ago
rebase.c
rebase.h
ref-filter.c Merge branch 'dr/push-remote-ref-update' 5 years ago
ref-filter.h oid_array: rename source file from sha1-array 5 years ago
reflog-walk.c
reflog-walk.h
refs.c
refs.h
refspec.c
refspec.h
remote-curl.c oid_array: rename source file from sha1-array 5 years ago
remote-testsvn.c
remote.c remote: drop "explicit" parameter from remote_ref_for_branch() 5 years ago
remote.h remote: drop "explicit" parameter from remote_ref_for_branch() 5 years ago
replace-object.c
replace-object.h
repo-settings.c
repository.c
repository.h
rerere.c
rerere.h
resolve-undo.c
resolve-undo.h
revision.c
revision.h
run-command.c
run-command.h
send-pack.c oid_array: rename source file from sha1-array 5 years ago
send-pack.h
sequencer.c Merge branch 'js/rebase-i-with-colliding-hash' into maint 5 years ago
sequencer.h Merge branch 'en/rebase-backend' 5 years ago
serve.c
serve.h
server-info.c
setup.c Merge branch 'es/outside-repo-errmsg-hints' 5 years ago
sh-i18n--envsubst.c
sha1-file.c packed_object_info(): use object_id for returning delta base 5 years ago
sha1-lookup.c
sha1-lookup.h
sha1-name.c oid_array: rename source file from sha1-array 5 years ago
sha1dc_git.c
sha1dc_git.h
shallow.c oid_array: rename source file from sha1-array 5 years ago
shell.c
shortlog.h
sideband.c
sideband.h
sigchain.c
sigchain.h
split-index.c
split-index.h
stable-qsort.c
strbuf.c
strbuf.h Merge branch 'bc/wildcard-credential' 5 years ago
streaming.c
streaming.h
string-list.c
string-list.h
sub-process.c
sub-process.h
submodule-config.c
submodule-config.h
submodule.c oid_array: rename source file from sha1-array 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-internal.h
transport.c oid_array: rename source file from sha1-array 5 years ago
transport.h
tree-diff.c
tree-walk.c
tree-walk.h
tree.c
tree.h
unicode-width.h unicode: update the width tables to Unicode 13.0 5 years ago
unimplemented.sh
unix-socket.c
unix-socket.h
unpack-trees.c Merge branch 'en/simplify-check-updates-in-unpack-trees' into maint 5 years ago
unpack-trees.h
upload-pack.c
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 Merge branch 'rs/show-progress-in-dumb-http-fetch' 5 years ago
walker.h remote-curl: show progress for fetches over dumb HTTP 5 years ago
wildmatch.c
wildmatch.h
worktree.c Merge branch 'hv/receive-denycurrent-everywhere' 5 years ago
worktree.h worktree: add utility to find worktree by pathname 5 years ago
wrap-for-bin.sh
wrapper.c
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