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.
 
 
 
 
 
 
Sergey Organov 564a4fc847 diff-merges: re-arrange functions to match the order they are called in 4 years ago
.github Merge branch 'js/ci-ghwf-dedup-tests' 4 years ago
Documentation Second batch 4 years ago
block-sha1
builtin diff-merges: rename diff_merges_default_to_enable() to match semantics 4 years ago
ci ci: do not skip tagged revisions in GitHub workflows 4 years ago
compat compat/mingw.h: drop extern from function declaration 4 years ago
contrib Merge branch 'dl/resurrect-update-for-sha256' 4 years ago
ewah
git-gui Merge https://github.com/prati0100/git-gui 4 years ago
gitk-git Merge remote-tracking branch 'paulus/master' into pm/gitk-update 4 years ago
gitweb
mergetools Merge branch 'ls/mergetool-meld-auto-merge' 4 years ago
negotiator negotiator/noop: add noop fetch negotiator 5 years ago
perl
po Merge branch 'master' of github.com:Softcatala/git-po 4 years ago
ppc
refs Merge branch 'hn/refs-trace-backend' 4 years ago
sha1collisiondetection@855827c583
sha1dc
sha256
t Merge branch 'cm/t7xxx-cleanup' 4 years ago
templates hooks--update.sample: use hash-agnostic zero OID 4 years ago
trace2
vcs-svn drop vcs-svn experiment 5 years ago
xdiff
.cirrus.yml
.clang-format
.editorconfig
.gitattributes
.gitignore Merge branch 'js/cmake-vs' 4 years ago
.gitmodules
.mailmap
.travis.yml
.tsan-suppressions
CODE_OF_CONDUCT.md
COPYING
GIT-VERSION-GEN Git 2.29.2 4 years ago
INSTALL
LGPL-2.1
Makefile revision: move diff merges functions to its own diff-merges.c 4 years ago
README.md
RelNotes Git 2.29.2 4 years ago
abspath.c
aclocal.m4
add-interactive.c strvec: rename struct fields 5 years ago
add-interactive.h
add-patch.c Merge branch 'dl/checkout-p-merge-base' 4 years ago
advice.c push: parse and set flag for "--force-if-includes" 4 years ago
advice.h push: parse and set flag for "--force-if-includes" 4 years ago
alias.c
alias.h
alloc.c
alloc.h
apply.c Merge branch 'jk/leakfix' 4 years ago
apply.h
archive-tar.c archive: read short blobs in archive.c::write_archive_entry() 4 years ago
archive-zip.c archive: read short blobs in archive.c::write_archive_entry() 4 years ago
archive.c archive: add --add-file 4 years ago
archive.h archive: add --add-file 4 years ago
attr.c
attr.h
banned.h
base85.c
bisect.c bisect--helper: reimplement `bisect_next` and `bisect_auto_next` shell functions in C 4 years ago
bisect.h bisect: combine args passed to find_bisection() 5 years ago
blame.c blame: handle deref_tag() returning NULL 4 years ago
blame.h
blob.c
blob.h
bloom.c builtin/commit-graph.c: introduce '--max-new-filters=<n>' 4 years ago
bloom.h bloom: encode out-of-bounds filters as non-empty 4 years ago
branch.c wt-status: tolerate dangling marks 4 years ago
branch.h
builtin.h Merge branch 'ds/maintenance-part-1' 4 years ago
bulk-checkin.c
bulk-checkin.h
bundle.c Merge branch 'jt/interpret-branch-name-fallback' 4 years ago
bundle.h Merge branch 'bc/sha-256-part-3' 5 years ago
cache-tree.c
cache-tree.h
cache.h builtin/clone: avoid failure with GIT_DEFAULT_HASH 4 years ago
chdir-notify.c
chdir-notify.h
check-builtins.sh
check_bindir
checkout.c config: drop git_config_get_string_const() 5 years ago
checkout.h
color.c
color.h
column.c Merge branch 'jk/strvec' 5 years ago
column.h
combine-diff.c Merge branch 'jk/diff-cc-oidfind-fix' 4 years ago
command-list.txt maintenance: create basic maintenance runner 4 years ago
commit-graph.c Merge branch 'tb/bloom-improvements' 4 years ago
commit-graph.h Merge branch 'tb/bloom-improvements' 4 years ago
commit-reach.c commit-reach: fix in_merge_bases_many bug 4 years ago
commit-reach.h
commit-slab-decl.h
commit-slab-impl.h
commit-slab.h
commit.c Merge branch 'jt/interpret-branch-name-fallback' 4 years ago
commit.h drop unused argc parameters 4 years ago
common-main.c
config.c Merge branch 'jk/leakfix' 4 years ago
config.h config: drop git_config_get_string_const() 5 years ago
config.mak.dev
config.mak.in
config.mak.uname
configure.ac
connect.c Merge branch 'jk/leakfix' 4 years ago
connect.h
connected.c Merge branch 'rs/more-buffered-io' 5 years ago
connected.h
convert.c convert: drop unused crlf_action from check_global_conv_flags_eol() 4 years ago
convert.h
copy.c
credential.c credential: treat CR/LF as line endings in the credential protocol 4 years ago
credential.h
csum-file.c
csum-file.h
ctype.c
daemon.c strvec: rename struct fields 5 years ago
date.c
decorate.c
decorate.h
delta-islands.c
delta-islands.h
delta.h
detect-compiler
diff-delta.c
diff-lib.c Merge branch 'so/combine-diff-simplify' 4 years ago
diff-merges.c diff-merges: re-arrange functions to match the order they are called in 4 years ago
diff-merges.h diff-merges: re-arrange functions to match the order they are called in 4 years ago
diff-no-index.c
diff.c diff: fix modified lines stats with --stat and --numstat 4 years ago
diff.h Merge branch 'so/combine-diff-simplify' 4 years ago
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 dir.c: drop unused "untracked" from treat_path_fast() 4 years ago
dir.h dir: fix problematic API to avoid memory leaks 5 years ago
editor.c config: fix leaks from git_config_get_string_const() 5 years ago
entry.c checkout_entry(): remove unreachable error() call 5 years ago
environment.c Merge branch 'jk/leakfix' 4 years ago
exec-cmd.c strvec: rename struct fields 5 years ago
exec-cmd.h
fetch-negotiator.c negotiator/noop: add noop fetch negotiator 5 years ago
fetch-negotiator.h
fetch-pack.c Merge branch 'jt/lazy-fetch' 4 years ago
fetch-pack.h Merge branch 'jt/lazy-fetch' 4 years ago
fmt-merge-msg.c
fmt-merge-msg.h
fsck.c
fsck.h
fsmonitor.c Merge branch 'jk/strvec' 5 years ago
fsmonitor.h
fuzz-commit-graph.c commit-graph: pass a 'struct repository *' in more places 4 years ago
fuzz-pack-headers.c
fuzz-pack-idx.c
generate-cmdlist.sh Fit to Plan 9's ANSI/POSIX compatibility layer 4 years ago
generate-configlist.sh
gettext.c
gettext.h
git-add--interactive.perl Merge branch 'dl/checkout-p-merge-base' 4 years ago
git-archimport.perl
git-bisect.sh Merge branch 'mr/bisect-in-c-2' 4 years ago
git-compat-util.h compat-util: type-check parameters of no-op replacement functions 5 years ago
git-cvsexportcommit.perl cvsexportcommit: do not run git programs in dashed form 4 years ago
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 git-p4: use HEAD~$n to find parent commit for unshelve 4 years ago
git-parse-remote.sh
git-quiltimport.sh
git-rebase--preserve-merges.sh rebase: remove unused function reschedule_last_action 5 years ago
git-request-pull.sh
git-send-email.perl
git-sh-i18n.sh
git-sh-setup.sh
git-submodule.sh Merge branch 'td/submodule-update-quiet' 4 years ago
git-svn.perl
git-web--browse.sh
git.c Merge branch 'js/no-builtins-on-disk-option' 4 years ago
git.rc
gpg-interface.c
gpg-interface.h
graph.c strvec: rename struct fields 5 years ago
graph.h
grep.c
grep.h
hash.h
hashmap.c
hashmap.h hashmap_for_each_entry(): workaround MSVC's runtime check failure #3 4 years ago
help.c help: do not expect built-in commands to be hardlinked 4 years ago
help.h help: do not expect built-in commands to be hardlinked 4 years ago
hex.c
http-backend.c
http-fetch.c
http-push.c strvec: rename struct fields 5 years ago
http-walker.c
http.c
http.h
ident.c Merge branch 'pw/rebase-i-more-options' 4 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: handle deref_tag() returning NULL 4 years ago
line-log.h
line-range.c
line-range.h
linear-assignment.c
linear-assignment.h
list-objects-filter-options.c fetch: do not override partial clone filter 4 years ago
list-objects-filter-options.h list_objects_filter_options: introduce 'list_object_filter_config_name' 5 years ago
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 'so/combine-diff-simplify' 4 years ago
log-tree.h
ls-refs.c strvec: rename struct fields 5 years ago
ls-refs.h
mailinfo.c
mailinfo.h
mailmap.c
mailmap.h
match-trees.c
mem-pool.c mem-pool: use consistent pool variable name 5 years ago
mem-pool.h mem-pool: use consistent pool variable name 5 years ago
merge-blobs.c
merge-blobs.h
merge-recursive.c Merge branch 'en/eol-attrs-gotchas' 5 years ago
merge-recursive.h merge-recursive: fix unclear and outright wrong comments 5 years ago
merge.c dir: fix problematic API to avoid memory leaks 5 years ago
mergesort.c
mergesort.h
midx.c Merge branch 'ds/maintenance-part-2' 4 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
notes.h
object-store.h sha1-file: introduce no-lazy-fetch has_object() 5 years ago
object.c
object.h maintenance: add auto condition for commit-graph task 4 years ago
oid-array.c
oid-array.h
oidmap.c
oidmap.h
oidset.c blame: validate and peel the object names on the ignore list 4 years ago
oidset.h blame: validate and peel the object names on the ignore list 4 years ago
pack-bitmap-write.c pack-bitmap-write: use hashwrite_be32() in write_hash_cache() 4 years ago
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-write: use hashwrite_be32() in write_idx_file() 4 years ago
pack.h
packfile.c Merge branch 'mt/delta-base-cache-races' 4 years ago
packfile.h midx: traverse the local MIDX first 4 years ago
pager.c
parse-options-cb.c assert PARSE_OPT_NONEG in parse-options callbacks 4 years ago
parse-options.c parse-options: add --git-completion-helper-all 5 years ago
parse-options.h messages: avoid SHA-1 in end-user facing messages 5 years ago
patch-delta.c
patch-ids.c
patch-ids.h
path.c sequencer: treat REVERT_HEAD as a pseudo ref 5 years ago
path.h sequencer: treat REVERT_HEAD as a pseudo ref 5 years ago
pathspec.c strvec: rename struct fields 5 years ago
pathspec.h
pkt-line.c
pkt-line.h
preload-index.c
pretty.c pretty: refactor `format_sanitized_subject()` 4 years ago
pretty.h pretty: refactor `format_sanitized_subject()` 4 years ago
prio-queue.c
prio-queue.h
progress.c Merge branch 'ma/stop-progress-null-fix' 5 years ago
progress.h
promisor-remote.c promisor-remote: remove unused variable 4 years ago
promisor-remote.h promisor-remote: remove unused variable 4 years ago
prompt.c
prompt.h
protocol.c protocol: re-enable v2 protocol by default 4 years ago
protocol.h
prune-packed.c
prune-packed.h
quote.c quote: turn 'nodq' parameter into a set of flags 4 years ago
quote.h quote: turn 'nodq' parameter into a set of flags 4 years ago
range-diff.c strvec: rename struct fields 5 years ago
range-diff.h
reachable.c
reachable.h
read-cache.c read-cache: fix mem-pool allocation for multi-threaded index loading 4 years ago
rebase-interactive.c
rebase-interactive.h
rebase.c
rebase.h
ref-filter.c Merge branch 'ma/worktree-cleanups' 4 years ago
ref-filter.h ref-filter: make internal reachable-filter API more precise 4 years ago
reflog-walk.c
reflog-walk.h
refs.c Merge branch 'hn/refs-trace-backend' 4 years ago
refs.h Merge branch 'jt/interpret-branch-name-fallback' 4 years ago
refspec.c Merge branch 'sb/clone-origin' 4 years ago
refspec.h Merge branch 'sb/clone-origin' 4 years ago
remote-curl.c push: parse and set flag for "--force-if-includes" 4 years ago
remote.c Merge branch 'sk/force-if-includes' 4 years ago
remote.h Merge branch 'sk/force-if-includes' 4 years ago
replace-object.c
replace-object.h
repo-settings.c Merge branch 'ds/maintenance-part-2' 4 years ago
repository.c
repository.h Merge branch 'ds/maintenance-part-2' 4 years ago
rerere.c
rerere.h
reset.c
reset.h
resolve-undo.c
resolve-undo.h
revision.c diff-merges: rename all functions to have common prefix 4 years ago
revision.h revision: move diff merges functions to its own diff-merges.c 4 years ago
run-command.c maintenance: replace run_auto_gc() 4 years ago
run-command.h maintenance: replace run_auto_gc() 4 years ago
send-pack.c Merge branch 'sk/force-if-includes' 4 years ago
send-pack.h
sequencer.c Merge branch 'jk/committer-date-is-author-date-fix' into maint 4 years ago
sequencer.h Merge branch 'pw/rebase-i-more-options' 4 years ago
serve.c strvec: rename struct fields 5 years ago
serve.h
server-info.c
setup.c Merge branch 'bc/sha-256-part-3' 5 years ago
sh-i18n--envsubst.c
sha1-file.c Merge branch 'jt/has_object' 5 years ago
sha1-lookup.c
sha1-lookup.h
sha1-name.c wt-status: tolerate dangling marks 4 years ago
sha1dc_git.c
sha1dc_git.h
shallow.c
shallow.h
shell.c
shortlog.h shortlog: allow multiple groups to be specified 4 years ago
sideband.c sideband: mark "remote error:" prefix for translation 5 years ago
sideband.h
sigchain.c
sigchain.h
split-index.c mem-pool: use more standard initialization and finalization 5 years ago
split-index.h
stable-qsort.c
strbuf.c
strbuf.h
streaming.c
streaming.h
string-list.c
string-list.h
strvec.c strvec: rename struct fields 5 years ago
strvec.h strvec: rename struct fields 5 years ago
sub-process.c
sub-process.h
submodule-config.c fetch: avoid reading submodule config until needed 5 years ago
submodule-config.h
submodule.c Merge branch 'so/combine-diff-simplify' 4 years ago
submodule.h submodule: rename helper functions to avoid ambiguity 5 years ago
symlinks.c
tag.c
tag.h
tar.h
tempfile.c
tempfile.h
thread-utils.c
thread-utils.h
tmp-objdir.c strvec: rename struct fields 5 years ago
tmp-objdir.h
trace.c
trace.h
trace2.c
trace2.h
trailer.c Merge branch 'jk/shortlog-group-by-trailer' 4 years ago
trailer.h trailer: add interface for iterating over commit trailers 4 years ago
transport-helper.c push: parse and set flag for "--force-if-includes" 4 years ago
transport-internal.h
transport.c push: parse and set flag for "--force-if-includes" 4 years ago
transport.h push: parse and set flag for "--force-if-includes" 4 years ago
tree-diff.c bloom/diff: properly short-circuit on max_changes 4 years ago
tree-walk.c
tree-walk.h
tree.c
tree.h
unicode-width.h
unimplemented.sh
unix-socket.c
unix-socket.h
unpack-trees.c
unpack-trees.h
upload-pack.c Merge branch 'rs/more-buffered-io' 5 years ago
upload-pack.h
url.c
url.h
urlmatch.c
urlmatch.h
usage.c
userdiff.c Merge branch 'sd/userdiff-css-update' 4 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 Merge branch 'ma/worktree-cleanups' 4 years ago
worktree.h Merge branch 'ma/worktree-cleanups' 4 years ago
wrap-for-bin.sh
wrapper.c xrealloc: do not reuse pointer freed by zero-length realloc() 4 years ago
write-or-die.c
ws.c
wt-status.c Merge branch 'ma/worktree-cleanups' 4 years ago
wt-status.h wt-status: introduce wt_status_state_free_buffers() 4 years ago
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