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.
 
 
 
 
 
 
Nguyễn Thái Ngọc Duy 7a60e3bb83 completion: use __gitcomp_builtin in _git_notes 7 years ago
.github
Documentation First batch after 2.16 7 years ago
block-sha1
builtin completion: use __gitcomp_builtin in _git_notes 7 years ago
ci travis-ci: check that all build artifacts are .gitignore-d 7 years ago
compat Merge branch 'bp/fsmonitor' 7 years ago
contrib completion: use __gitcomp_builtin in _git_notes 7 years ago
ewah
git-gui Merge branch 'js/misc-git-gui-stuff' of ../git-gui 7 years ago
gitk-git
gitweb
mergetools
perl perl/Git: remove now useless email-address parsing code 7 years ago
po l10n: de.po: translate 72 new messages 7 years ago
ppc
refs Merge branch 'mh/avoid-rewriting-packed-refs' into maint 7 years ago
sha1collisiondetection@19d97bf5af
sha1dc
t completion: use __gitcomp_builtin in _git_checkout 7 years ago
templates fsmonitor: simplify determining the git worktree under Windows 7 years ago
vcs-svn
xdiff Merge branch 'jt/diff-anchored-patience' 7 years ago
.clang-format
.gitattributes
.gitignore
.gitmodules
.mailmap
.travis.yml travis-ci: don't install default addon packages for the 32 bit Linux build 7 years ago
.tsan-suppressions
COPYING
GIT-VERSION-GEN Git 2.16.1 7 years ago
INSTALL
LGPL-2.1
Makefile Merge branch 'ab/dc-sha1-loose-ends' 7 years ago
README.md
RelNotes Git 2.16.1 7 years ago
abspath.c
aclocal.m4
advice.c Merge branch 'ls/editor-waiting-message' 7 years ago
advice.h Merge branch 'ls/editor-waiting-message' 7 years ago
alias.c
alloc.c
apply.c completion: use __gitcomp_builtin in _git_apply 7 years ago
apply.h
archive-tar.c
archive-zip.c
archive.c
archive.h
argv-array.c
argv-array.h
attr.c
attr.h
base85.c
bisect.c Merge branch 'ys/bisect-object-id-missing-conversion-fix' 7 years ago
bisect.h Merge branch 'ma/bisect-leakfix' 7 years ago
blame.c Merge branch 'bw/diff-opt-impl-to-bitfields' 7 years ago
blame.h
blob.c
blob.h
branch.c Merge branch 'ks/branch-cleanup' 7 years ago
branch.h Merge branch 'ks/branch-cleanup' 7 years ago
builtin.h
bulk-checkin.c
bulk-checkin.h
bundle.c Merge branch 'rs/lose-leak-pending' 7 years ago
bundle.h
cache-tree.c
cache-tree.h
cache.h Merge branch 'ew/empty-merge-with-dirty-index-maint' into ew/empty-merge-with-dirty-index 7 years ago
check-builtins.sh
check-racy.c
check_bindir
checkout.c checkout: factor out functions to new lib file 7 years ago
checkout.h checkout: factor out functions to new lib file 7 years ago
color.c refactor "dumb" terminal determination 7 years ago
color.h
column.c
column.h
combine-diff.c diff: introduce DIFF_PICKAXE_KINDS_MASK 7 years ago
command-list.txt
commit-slab.h
commit.c commit: remove unused function clear_commit_marks_for_object_array() 7 years ago
commit.h Merge branch 'rs/lose-leak-pending' 7 years ago
common-main.c
config.c Merge branch 'hm/config-parse-expiry-date' 7 years ago
config.h Merge branch 'hm/config-parse-expiry-date' 7 years ago
config.mak.in
config.mak.uname
configure.ac Makefile: NO_OPENSSL=1 should no longer imply BLK_SHA1=1 7 years ago
connect.c connect: correct style of C-style comment 7 years ago
connect.h
connected.c
connected.h
convert.c Merge branch 'tb/check-crlf-for-safe-crlf' 7 years ago
convert.h
copy.c
credential-cache--daemon.c
credential-cache.c
credential-store.c
credential.c
credential.h
csum-file.c
csum-file.h
ctype.c
daemon.c
date.c
decorate.c decorate: clean up and document API 7 years ago
decorate.h decorate: clean up and document API 7 years ago
delta.h
diff-delta.c
diff-lib.c Merge branch 'bc/hash-algo' 7 years ago
diff-no-index.c
diff.c Merge branch 'sb/diff-blobfind-pickaxe' 7 years ago
diff.h Merge branch 'sb/diff-blobfind-pickaxe' 7 years ago
diffcore-break.c
diffcore-delta.c
diffcore-order.c
diffcore-pickaxe.c diff: properly error out when combining multiple pickaxe options 7 years ago
diffcore-rename.c diffcore-rename: make diff-tree -l0 mean -l<large> 7 years ago
diffcore.h
dir-iterator.c
dir-iterator.h
dir.c Merge branch 'jh/object-filtering' 7 years ago
dir.h Merge branch 'jh/object-filtering' 7 years ago
editor.c launch_editor(): indicate that Git waits for user input 7 years ago
entry.c Merge branch 'bp/fsmonitor' 7 years ago
environment.c Merge branch 'ar/unconfuse-three-dots' 7 years ago
exec_cmd.c
exec_cmd.h
fast-import.c
fetch-pack.c Merge branch 'jk/fewer-pack-rescan' 7 years ago
fetch-pack.h
fmt-merge-msg.h
fsck.c
fsck.h
fsmonitor.c fsmonitor: store fsmonitor bitmap before splitting index 7 years ago
fsmonitor.h fsmonitor: store fsmonitor bitmap before splitting index 7 years ago
generate-cmdlist.sh generate-cmdlist: avoid non-deterministic output 7 years ago
gettext.c
gettext.h
git-add--interactive.perl add--interactive: ignore submodule changes except HEAD 7 years ago
git-archimport.perl
git-bisect.sh Merge branch 'sb/bisect-run-empty' 7 years ago
git-compat-util.h git-compat-util: introduce skip_to_optional_arg() 7 years ago
git-cvsexportcommit.perl
git-cvsimport.perl cvsimport: apply shell-quoting regex globally 7 years ago
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-p4: update multiple shelved change lists 7 years ago
git-parse-remote.sh
git-quiltimport.sh
git-rebase--am.sh rebase: use mboxrd format to avoid split errors 7 years ago
git-rebase--interactive.sh Merge branch 'js/fix-merge-arg-quoting-in-rebase-p' 7 years ago
git-rebase--merge.sh
git-rebase.sh rebase: rebasing can also be done when HEAD is detached 7 years ago
git-remote-testgit.sh
git-request-pull.sh
git-send-email.perl send-email: add and use a local copy of Mail::Address 7 years ago
git-sh-i18n.sh
git-sh-setup.sh
git-stash.sh Merge branch 'tg/stash-with-pathspec-fix' 7 years ago
git-submodule.sh
git-svn.perl Merge branch 'jm/svn-pushmergeinfo-fix' 7 years ago
git-web--browse.sh
git.c Merge branch 'ma/branch-list-paginate' 7 years ago
git.rc
gpg-interface.c
gpg-interface.h
graph.c
graph.h
grep.c Merge branch 'ab/pcre2-grep' 7 years ago
grep.h Merge branch 'ab/pcre-v2' into maint 7 years ago
hash.h Add structure representing hash algorithm 7 years ago
hashmap.c
hashmap.h hashmap: adjust documentation to reflect reality 7 years ago
help.c version --build-options: report commit, too, if possible 7 years ago
help.h
hex.c
http-backend.c
http-fetch.c
http-push.c
http-walker.c
http.c Merge branch 'rs/use-argv-array-in-child-process' 7 years ago
http.h
ident.c
imap-send.c imap-send: URI encode server folder 7 years ago
iterator.h
khash.h
kwset.c
kwset.h
levenshtein.c
levenshtein.h
line-log.c
line-log.h
line-range.c
line-range.h
list-objects-filter-options.c list-objects-filter-options: support --no-filter 7 years ago
list-objects-filter-options.h list-objects-filter-options: support --no-filter 7 years ago
list-objects-filter.c list-objects: filter objects in traverse_commit_list 7 years ago
list-objects-filter.h list-objects: filter objects in traverse_commit_list 7 years ago
list-objects.c Merge branch 'sb/describe-blob' 7 years ago
list-objects.h list-objects: filter objects in traverse_commit_list 7 years ago
list.h
ll-merge.c
ll-merge.h
lockfile.c
lockfile.h
log-tree.c log: add option to choose which refs to decorate 7 years ago
log-tree.h log: add option to choose which refs to decorate 7 years ago
mailinfo.c
mailinfo.h
mailmap.c
mailmap.h
match-trees.c
merge-blobs.c
merge-blobs.h
merge-recursive.c Merge branch 'jc/merge-symlink-ours-theirs' 7 years ago
merge-recursive.h
merge.c Merge branch 'ew/empty-merge-with-dirty-index-maint' into ew/empty-merge-with-dirty-index 7 years ago
mergesort.c
mergesort.h
mru.c
mru.h
name-hash.c
notes-cache.c
notes-cache.h
notes-merge.c Switch empty tree and blob lookups to use hash abstraction 7 years ago
notes-merge.h
notes-utils.c
notes-utils.h
notes.c
notes.h
object.c object: add clear_commit_marks_all() 7 years ago
object.h Merge branch 'rs/lose-leak-pending' 7 years ago
oidmap.c oidmap: ensure map is initialized 7 years ago
oidmap.h oidmap: add oidmap iterator methods 7 years ago
oidset.c oidset: add iterator methods to oidset 7 years ago
oidset.h oidset: don't return value from oidset_init 7 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: support --git-completion-helper 7 years ago
parse-options.h completion: use __gitcomp_builtin in _git_am 7 years ago
patch-delta.c
patch-ids.c
patch-ids.h
path.c
path.h path: document path functions 7 years ago
pathspec.c
pathspec.h Merge branch 'bw/pathspec-match-submodule-boundary' 7 years ago
pkt-line.c Merge branch 'bw/protocol-v1' 7 years ago
pkt-line.h
preload-index.c
pretty.c log: add option to choose which refs to decorate 7 years ago
pretty.h format: create docs for pretty.h 7 years ago
prio-queue.c
prio-queue.h
progress.c Merge branch 'en/rename-progress' 7 years ago
progress.h progress: fix progress meters when dealing with lots of work 7 years ago
prompt.c
prompt.h
protocol.c
protocol.h
quote.c
quote.h
reachable.c
reachable.h
read-cache.c Merge branch 'tb/add-renormalize' 7 years ago
ref-filter.c Merge branch 'rs/lose-leak-pending' 7 years ago
ref-filter.h
reflog-walk.c
reflog-walk.h
refs.c log: add option to choose which refs to decorate 7 years ago
refs.h log: add option to choose which refs to decorate 7 years ago
remote-curl.c
remote-testsvn.c
remote.c Merge branch 'js/for-each-ref-remote-name-and-ref' 7 years ago
remote.h
replace_object.c
repository.c repository: pre-initialize hash algo pointer 7 years ago
repository.h Integrate hash algorithm support with repo setup 7 years ago
rerere.c
rerere.h completion: use __gitcomp_builtin in _git_am 7 years ago
resolve-undo.c
resolve-undo.h
revision.c Merge branch 'sb/diff-blobfind-pickaxe' 7 years ago
revision.h Merge branch 'rs/lose-leak-pending' 7 years ago
run-command.c
run-command.h
send-pack.c send-pack: use internal argv_array of struct child_process 7 years ago
send-pack.h
sequencer.c sequencer: do not invent whitespace when transforming OIDs 7 years ago
sequencer.h rebase -i: learn to abbreviate command names 7 years ago
server-info.c
setup.c Merge branch 'sg/setup-doc-update' 7 years ago
sh-i18n--envsubst.c
sha1-array.c
sha1-array.h
sha1-lookup.c
sha1-lookup.h
sha1_file.c Merge branch 'ds/for-each-file-in-obj-micro-optim' 7 years ago
sha1_name.c Merge branch 'jc/branch-name-sanity' 7 years ago
sha1dc_git.c
sha1dc_git.h
shallow.c
shell.c
shortlog.h
show-index.c
sideband.c refactor "dumb" terminal determination 7 years ago
sideband.h
sigchain.c
sigchain.h
split-index.c
split-index.h
strbuf.c Merge branch 'jd/fix-strbuf-add-urlencode-bytes' 7 years ago
strbuf.h strbuf: remove unused stripspace function alias 7 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 submodule: submodule_move_head omits old argument in forced case 7 years ago
submodule.h submodule: convert get_next_submodule to not rely on the_index 7 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.h
trace.c trace: improve performance while category is disabled 7 years ago
trace.h trace: improve performance while category is disabled 7 years ago
trailer.c
trailer.h
transport-helper.c Merge branch 'jt/transport-hide-vtable' 7 years ago
transport-internal.h transport: make transport vtable more private 7 years ago
transport.c Merge branch 'jt/transport-hide-vtable' 7 years ago
transport.h transport: make transport vtable more private 7 years ago
tree-diff.c
tree-walk.c Merge branch 'bw/pathspec-match-submodule-boundary' 7 years ago
tree-walk.h
tree.c
tree.h
unicode_width.h
unimplemented.sh
unix-socket.c
unix-socket.h
unpack-trees.c unpack-trees: oneway_merge to update submodules 7 years ago
unpack-trees.h
upload-pack.c Merge branch 'bw/protocol-v1' 7 years ago
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 --build-options: report commit, too, if possible 7 years ago
version.h version --build-options: report commit, too, if possible 7 years ago
versioncmp.c
walker.c
walker.h
wildmatch.c
wildmatch.h
worktree.c
worktree.h
wrap-for-bin.sh
wrapper.c
write_or_die.c
ws.c
wt-status.c Merge branch 'nd/ita-wt-renames-in-status' 7 years ago
wt-status.h Merge branch 'nd/ita-wt-renames-in-status' 7 years ago
xdiff-interface.c
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 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-.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