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 773e3a2e02 Git 2.11.2 8 years ago
Documentation Git 2.11.2 8 years ago
block-sha1
builtin Merge branch 'jk/blame-fixes' into maint 8 years ago
ci
compat Merge branch 'js/mingw-isatty' into maint 8 years ago
contrib Merge branch 'ls/filter-process' into maint 8 years ago
ewah
git-gui git-gui 0.21.0 8 years ago
gitk-git
gitweb Merge branch 'ab/gitweb-abbrev-links' 8 years ago
mergetools Merge branch 'da/mergetool-xxdiff-hotkey' into maint 8 years ago
perl git-svn: allow "0" in SVN path components 8 years ago
po Merge branch 'russian-l10n' of https://github.com/DJm00n/git-po-ru 8 years ago
ppc
refs Merge branch 'jk/ref-symlink-loop' 8 years ago
t Merge branch 'jk/grep-e-could-be-extended-beyond-posix' into maint 8 years ago
templates pre-receive.sample: mark it executable 8 years ago
vcs-svn Merge branch 'mr/vcs-svn-printf-ulong' into maint 8 years ago
xdiff Merge branch 'mh/diff-indent-heuristic' 8 years ago
.gitattributes
.gitignore Merge branch 'bb/unicode-9.0' into maint 8 years ago
.mailmap add David Turner's Two Sigma address 8 years ago
.travis.yml travis-ci: fix Perforce install on macOS 8 years ago
COPYING
GIT-VERSION-GEN Git 2.11.2 8 years ago
INSTALL
LGPL-2.1
Makefile Makefile: exclude contrib from FIND_SOURCE_FILES 8 years ago
README.md README: replace gmane link with public-inbox 8 years ago
RelNotes Git 2.11.2 8 years ago
abspath.c
aclocal.m4
advice.c
advice.h
alias.c
alloc.c
apply.c i18n: apply: mark error message for translation 8 years ago
apply.h
archive-tar.c
archive-zip.c archive-zip: load userdiff config 8 years ago
archive.c archive: read local configuration 8 years ago
archive.h archive: read local configuration 8 years ago
argv-array.c
argv-array.h
attr.c read info/{attributes,exclude} only when in repository 8 years ago
attr.h
base85.c
bisect.c use QSORT 8 years ago
bisect.h
blob.c
blob.h
branch.c worktree.c: get_worktrees() takes a new flag argument 8 years ago
branch.h create_branch: drop unused "head" parameter 8 years ago
builtin.h
bulk-checkin.c compression: unify pack.compression configuration parsing 8 years ago
bulk-checkin.h
bundle.c
bundle.h
cache-tree.c
cache-tree.h
cache.h Merge branch 'sb/in-core-index-doc' into maint 8 years ago
check-builtins.sh
check-racy.c
check_bindir
color.c Merge branch 'jk/squelch-false-warning-from-gcc-o3' into maint 8 years ago
color.h
column.c
column.h
combine-diff.c diff_aligned_abbrev: use "struct oid" 8 years ago
command-list.txt
commit-slab.h
commit.c Merge branch 'rs/copy-array' into maint 8 years ago
commit.h Merge branch 'nd/shallow-deepen' 8 years ago
common-main.c common-main: stop munging argv[0] path 8 years ago
config.c Merge branch 'nd/config-misc-fixes' into maint 8 years ago
config.mak.in
config.mak.uname
configure.ac Merge branch 'dp/autoconf-curl-ssl' into maint 8 years ago
connect.c Merge branch 'ls/filter-process' 8 years ago
connect.h
connected.c check_connected: accept an env argument 8 years ago
connected.h check_connected: accept an env argument 8 years ago
convert.c Merge branch 'jc/renormalize-merge-kill-safer-crlf' into maint 8 years ago
convert.h
copy.c
credential-cache--daemon.c i18n: credential-cache--daemon: mark advice for translation 8 years ago
credential-cache.c
credential-store.c
credential.c
credential.h
csum-file.c
csum-file.h
ctype.c
daemon.c Merge branch 'jk/daemon-path-ok-check-truncation' into maint 8 years ago
date.c
decorate.c
decorate.h
delta.h
diff-delta.c
diff-lib.c commit: fix empty commit creation when there's no changes but ita entries 8 years ago
diff-no-index.c Merge branch 'jk/setup-sequence-update' 8 years ago
diff.c diff: handle --no-abbrev in no-index case 8 years ago
diff.h Merge branch 'nd/ita-empty-commit' 8 years ago
diffcore-break.c Merge branch 'tk/diffcore-delta-remove-unused' into maint 8 years ago
diffcore-delta.c Merge branch 'tk/diffcore-delta-remove-unused' 8 years ago
diffcore-order.c use QSORT 8 years ago
diffcore-pickaxe.c Merge branch 'js/regexec-buf' into maint 8 years ago
diffcore-rename.c Merge branch 'tk/diffcore-delta-remove-unused' into maint 8 years ago
diffcore.h Merge branch 'tk/diffcore-delta-remove-unused' into maint 8 years ago
dir-iterator.c
dir-iterator.h
dir.c read info/{attributes,exclude} only when in repository 8 years ago
dir.h ls-files: add pathspec matching for submodules 8 years ago
editor.c
entry.c
environment.c compression: unify pack.compression configuration parsing 8 years ago
exec_cmd.c Merge branch 'js/exec-path-coverity-workaround' into maint 8 years ago
exec_cmd.h common-main: stop munging argv[0] path 8 years ago
fast-import.c Merge branch 'mh/fast-import-notes-fix-new' into maint 8 years ago
fetch-pack.c fetch-pack.c: correct command at the beginning of an error message 8 years ago
fetch-pack.h
fmt-merge-msg.h
fsck.c fsck: handle bad trees like other errors 8 years ago
fsck.h
generate-cmdlist.sh
gettext.c
gettext.h
git-add--interactive.perl diff: improve positioning of add/delete blocks in diffs 8 years ago
git-archimport.perl
git-bisect.sh
git-compat-util.h Merge branch 'jk/common-main' into maint-2.10 8 years ago
git-cvsexportcommit.perl
git-cvsimport.perl
git-cvsserver.perl
git-difftool--helper.sh
git-difftool.perl Merge branch 'jk/difftool-in-subdir' into maint 8 years ago
git-filter-branch.sh
git-instaweb.sh
git-merge-octopus.sh
git-merge-one-file.sh
git-merge-resolve.sh
git-mergetool--lib.sh mergetool: honor mergetool.$tool.trustExitCode for built-in tools 8 years ago
git-mergetool.sh mergetool: honor -O<orderfile> 8 years ago
git-p4.py Merge branch 'gv/p4-multi-path-commit-fix' into maint 8 years ago
git-parse-remote.sh
git-quiltimport.sh
git-rebase--am.sh
git-rebase--interactive.sh Merge branch 'jk/rebase-i-squash-count-fix' into maint 8 years ago
git-rebase--merge.sh
git-rebase.sh
git-relink.perl
git-remote-testgit.sh
git-request-pull.sh request-pull: drop old USAGE stuff 8 years ago
git-send-email.perl
git-sh-i18n.sh
git-sh-setup.sh git-sh-setup: be explicit where to dot-source git-sh-i18n from. 8 years ago
git-stash.sh Merge branch 'jk/stash-disable-renames-internally' into maint 8 years ago
git-submodule.sh clone: pass --progress decision to recursive submodules 8 years ago
git-svn.perl git-svn: "git worktree" awareness 8 years ago
git-web--browse.sh
git.c execv_dashed_external: wait for child on signal death 8 years ago
git.rc
gpg-interface.c gpg-interface: use more status letters 8 years ago
gpg-interface.h
graph.c Merge branch 'jk/graph-padding-fix' into maint 8 years ago
graph.h
grep.c Merge branch 'js/regexec-buf' into maint 8 years ago
grep.h
hashmap.c
hashmap.h
help.c use QSORT 8 years ago
help.h
hex.c hex: make wraparound of the index into ring-buffer explicit 8 years ago
http-backend.c pkt-line: rename packet_write() to packet_write_fmt() 8 years ago
http-fetch.c
http-push.c
http-walker.c http-walker: complain about non-404 loose object errors 8 years ago
http.c Merge branch 'jk/http-walker-limit-redirect' into maint 8 years ago
http.h Merge branch 'jk/http-walker-limit-redirect' into maint 8 years ago
ident.c Merge branch 'jk/ident-ai-canonname-could-be-null' into maint 8 years ago
imap-send.c Merge branch 'jc/cocci-xstrdup-or-null' into maint 8 years ago
iterator.h
khash.h
kwset.c
kwset.h
levenshtein.c
levenshtein.h
line-log.c use QSORT 8 years ago
line-log.h
line-range.c
line-range.h
list-objects.c
list-objects.h
list.h
ll-merge.c
ll-merge.h
lockfile.c
lockfile.h
log-tree.c
log-tree.h
mailinfo.c Merge branch 'jt/mailinfo-fold-in-body-headers' into maint 8 years ago
mailinfo.h mailinfo: handle in-body header continuations 8 years ago
mailmap.c cocci: refactor common patterns to use xstrdup_or_null() 8 years ago
mailmap.h
match-trees.c
merge-blobs.c
merge-blobs.h
merge-recursive.c Merge branch 'nd/qsort-in-merge-recursive' into maint 8 years ago
merge-recursive.h
merge.c
mergesort.c
mergesort.h
mru.c
mru.h
name-hash.c
notes-cache.c
notes-cache.h
notes-merge.c Merge branch 'va/i18n-more' 8 years ago
notes-merge.h
notes-utils.c
notes-utils.h
notes.c
notes.h
object.c
object.h
pack-bitmap-write.c use QSORT 8 years ago
pack-bitmap.c sha1_file: rename git_open_noatime() to git_open() 8 years ago
pack-bitmap.h
pack-check.c Merge branch 'jk/verify-packfile-gently' into maint 8 years ago
pack-objects.c
pack-objects.h
pack-revindex.c use COPY_ARRAY 8 years ago
pack-revindex.h
pack-write.c use QSORT 8 years ago
pack.h
pager.c Merge branch 'jk/setup-sequence-update' 8 years ago
parse-options-cb.c Merge branch 'rs/cocci' 8 years ago
parse-options.c parse-options: print "fatal:" before usage_msg_opt() 8 years ago
parse-options.h Merge branch 'mh/diff-indent-heuristic' 8 years ago
patch-delta.c
patch-ids.c
patch-ids.h
path.c Merge branch 'js/normalize-path-copy-ceil' into maint 8 years ago
pathspec.c Merge branch 'ex/deprecate-empty-pathspec-as-match-all' 8 years ago
pathspec.h Merge branch 'bw/pathspec-remove-unused-extern-decl' into maint 8 years ago
pkt-line.c pkt-line: add functions to read/write flush terminated packet streams 8 years ago
pkt-line.h pkt-line: add functions to read/write flush terminated packet streams 8 years ago
preload-index.c
pretty.c Merge branch 'rs/cocci' into maint 8 years ago
prio-queue.c
prio-queue.h
progress.c
progress.h
prompt.c
prompt.h
quote.c
quote.h
reachable.c
reachable.h
read-cache.c cache.h: document remove_index_entry_at 8 years ago
ref-filter.c Merge branch 'jc/for-each-ref-head-segfault-fix' 8 years ago
ref-filter.h
reflog-walk.c
reflog-walk.h
refs.c Merge branch 'jc/cocci-xstrdup-or-null' 8 years ago
refs.h Merge branch 'nd/shallow-deepen' 8 years ago
remote-curl.c Merge branch 'dt/smart-http-detect-server-going-away' into maint 8 years ago
remote-testsvn.c
remote.c Merge branch 'km/branch-get-push-while-detached' into maint 8 years ago
remote.h
replace_object.c
rerere.c
rerere.h
resolve-undo.c
resolve-undo.h
revision.c Merge branch 'vn/revision-shorthand-for-side-branch-log' 8 years ago
revision.h
run-command.c execv_dashed_external: wait for child on signal death 8 years ago
run-command.h execv_dashed_external: wait for child on signal death 8 years ago
send-pack.c cocci: refactor common patterns to use xstrdup_or_null() 8 years ago
send-pack.h
sequencer.c Revert "sequencer: remove useless get_dir() function" 8 years ago
sequencer.h sequencer: get rid of the subcommand field 8 years ago
server-info.c use QSORT 8 years ago
setup.c
sh-i18n--envsubst.c remove unnecessary check before QSORT 8 years ago
sha1-array.c Merge branch 'rs/qsort' 8 years ago
sha1-array.h sha1_array: let callbacks interrupt iteration 8 years ago
sha1-lookup.c
sha1-lookup.h
sha1_file.c Merge branch 'jk/quote-env-path-list-component' into maint 8 years ago
sha1_name.c Merge branch 'jk/no-looking-at-dotgit-outside-repo' 8 years ago
shallow.c Merge branch 'nd/shallow-fixup' into maint 8 years ago
shell.c Merge branch 'maint-2.8' into maint-2.9 8 years ago
shortlog.h
show-index.c
sideband.c
sideband.h
sigchain.c
sigchain.h
split-index.c split-index: s/eith/with/ typo fix 8 years ago
split-index.h
strbuf.c link_alt_odb_entry: handle normalize_path errors 8 years ago
strbuf.h link_alt_odb_entry: handle normalize_path errors 8 years ago
streaming.c Merge branch 'jk/pack-objects-optim-mru' 8 years ago
streaming.h
string-list.c use QSORT 8 years ago
string-list.h
submodule-config.c
submodule-config.h
submodule.c Merge branch 'bw/push-dry-run' into maint 8 years ago
submodule.h push: fix --dry-run to not push submodules 8 years ago
symlinks.c
tag.c
tag.h
tar.h
tempfile.c
tempfile.h
thread-utils.c
thread-utils.h
tmp-objdir.c tmp-objdir: quote paths we add to alternates 8 years ago
tmp-objdir.h tmp-objdir: introduce API for temporary object directories 8 years ago
trace.c
trace.h
trailer.c Merge branch 'jt/trailer-with-cruft' 8 years ago
trailer.h
transport-helper.c Merge branch 'nd/shallow-deepen' 8 years ago
transport.c Merge branch 'bw/push-dry-run' into maint 8 years ago
transport.h Merge branch 'jc/abbrev-auto' 8 years ago
tree-diff.c
tree-walk.c fsck: handle bad trees like other errors 8 years ago
tree-walk.h fsck: handle bad trees like other errors 8 years ago
tree.c use QSORT 8 years ago
tree.h
unicode_width.h unicode_width.h: update the width tables to Unicode 9.0 8 years ago
unimplemented.sh
unix-socket.c
unix-socket.h
unpack-trees.c Merge branch 'sb/unpack-trees-grammofix' into maint 8 years ago
unpack-trees.h
upload-pack.c upload-pack: optionally allow fetching any sha1 8 years ago
url.c
url.h
urlmatch.c
urlmatch.h
usage.c Merge branch 'cc/apply-am' 8 years ago
userdiff.c
userdiff.h
utf8.c utf8: accept "latin-1" as ISO-8859-1 8 years ago
utf8.h
varint.c
varint.h
version.c
version.h
versioncmp.c
walker.c
walker.h
wildmatch.c
wildmatch.h
worktree.c worktree list: keep the list sorted 8 years ago
worktree.h worktree list: keep the list sorted 8 years ago
wrap-for-bin.sh
wrapper.c
write_or_die.c run-command: move check_pipe() from write_or_die to run_command 8 years ago
ws.c
wt-status.c Merge branch 'nd/ita-empty-commit' 8 years ago
wt-status.h wt-status: teach has_{unstaged,uncommitted}_changes() about submodules 8 years ago
xdiff-interface.c Merge branch 'js/regexec-buf' into maint 8 years ago
xdiff-interface.h
zlib.c

README.md

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 http://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-.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://public-inbox.org/git, http://marc.info/?l=git and other archival sites.

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