A fork of Git containing Microsoft-specific patches.
Перейти к файлу
Johannes Schindelin 97b25226d1
Merge pull request #145 from microsoft/kg/external-diff-save-env
Fix problems with `git difftool` and a large number of files
2019-05-29 15:07:37 +02:00
.github
Documentation core.txt: fixup typo in gitlink for check-docs 2019-03-27 10:25:58 -04:00
block-sha1
builtin Merge branch 'jk/no-sigpipe-during-network-transport' 2019-05-03 19:04:13 +02:00
ci
compat fixup! mingw: kill child processes in a gentler way 2019-05-10 22:17:37 +02:00
contrib
ewah
git-gui
gitk-git
gitweb
mergetools
negotiator
perl
po
ppc
refs
sha1collisiondetection@232357eb2e
sha1dc
t t6500(mingw): use the Windows PID of the shell 2019-05-05 01:22:57 +02:00
templates
trace2 trace2: create new combined trace facility 2019-02-05 15:52:25 -05:00
vcs-svn
xdiff
.clang-format trace2: add for_each macros to clang-format 2019-02-05 16:00:46 -05:00
.editorconfig
.gitattributes
.gitignore
.gitmodules
.mailmap
.travis.yml
.tsan-suppressions
BRANCHES.md BRANCHES.md: Add explanation of branches and using forks 2018-12-18 08:45:42 -07:00
CODE_OF_CONDUCT.md
CONTRIBUTING.md
COPYING
GIT-VERSION-GEN
INSTALL
LGPL-2.1
Makefile trace2: t/helper/test-trace2, t0210.sh, t0211.sh, t0212.sh 2019-02-05 16:00:46 -05:00
README.md
RelNotes
abspath.c
aclocal.m4
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 ci: move the Windows jobs to the top 2019-05-10 22:17:08 +02:00
banned.h
base85.c
bisect.c
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 fixup! pager: fix order of atexit() calls 2019-02-13 16:45:47 -05:00
chdir-notify.c
chdir-notify.h
check-builtins.sh
check-racy.c
check_bindir
checkout.c
checkout.h
color.c
color.h
column.c
column.h
combine-diff.c
command-list.txt
commit-graph.c
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 trace2: collect Windows-specific process information 2019-02-05 15:57:45 -05:00
config.c trace2: create new combined trace facility 2019-02-05 15:52:25 -05:00
config.h
config.mak.dev
config.mak.in
config.mak.uname mingw: allow building with an MSYS2 runtime v3.x 2019-05-03 19:01:27 +02:00
configure.ac
connect.c trace2:data: add trace2 transport child classification 2019-02-05 15:57:53 -05:00
connect.h
connected.c
connected.h
convert.c fixup! gvfs: ensure all filters and EOL conversions are blocked 2019-02-28 12:35:36 -05:00
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.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 'kg/external-diff-save-env' 2019-05-29 10:50:08 +02:00
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
dir.h
editor.c trace2:data: add editor/pager child classification 2019-02-05 15:57:52 -05:00
entry.c
environment.c
exec-cmd.c trace2: create new combined trace facility 2019-02-05 15:52:25 -05:00
exec-cmd.h
fast-import.c
fetch-negotiator.c
fetch-negotiator.h
fetch-object.c
fetch-object.h
fetch-pack.c Merge branch 'jk/no-sigpipe-during-network-transport' 2019-05-03 19:04:13 +02:00
fetch-pack.h
fmt-merge-msg.h
fsck.c
fsck.h
fsmonitor.c
fsmonitor.h
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 trace2: create new combined trace facility 2019-02-05 15:52:25 -05:00
git-cvsexportcommit.perl
git-cvsimport.perl
git-cvsserver.perl
git-difftool--helper.sh
git-filter-branch.sh
git-instaweb.sh
git-legacy-rebase--interactive.sh
git-legacy-rebase.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--am.sh
git-rebase--common.sh
git-rebase--merge.sh
git-rebase--preserve-merges.sh
git-remote-testgit.sh
git-request-pull.sh
git-send-email.perl
git-sh-i18n.sh
git-sh-setup.sh
git-submodule.sh
git-svn.perl
git-web--browse.sh
git.c fixup! pager: fix order of atexit() calls 2019-02-13 16:45:47 -05:00
git.rc
gpg-interface.c
gpg-interface.h
graph.c
graph.h
grep.c
grep.h
gvfs.c
gvfs.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: allow building with GCC 8 2019-05-10 22:17:37 +02:00
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
log-tree.h
ls-refs.c
ls-refs.h
mailinfo.c
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 trace2:data: add trace2 data to midx 2019-02-28 11:39:43 -05:00
midx.h multi-pack-index: prepare 'repack' subcommand 2018-12-21 09:36:20 -05:00
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
oidmap.c
oidmap.h
oidset.c
oidset.h
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 midx: verify: group objects by packfile to speed up object verification 2019-02-28 09:29:29 -05:00
packfile.h midx: verify: group objects by packfile to speed up object verification 2019-02-28 09:29:29 -05:00
pager.c fixup! pager: fix order of atexit() calls 2019-02-13 16:45:47 -05:00
parse-options-cb.c
parse-options.c
parse-options.h
patch-delta.c
patch-ids.c
patch-ids.h
path.c
path.h
pathspec.c
pathspec.h
pkt-line.c Merge branch 'jk/no-sigpipe-during-network-transport' 2019-05-03 19:04:13 +02:00
pkt-line.h
preload-index.c
pretty.c
pretty.h
prio-queue.c
prio-queue.h
progress.c
progress.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 trace2:data: add trace2 instrumentation to index read/write 2019-02-05 15:57:53 -05:00
rebase-interactive.c
rebase-interactive.h
ref-filter.c
ref-filter.h
reflog-walk.c
reflog-walk.h
refs.c
refs.h
refspec.c
refspec.h
remote-curl.c trace2: create new combined trace facility 2019-02-05 15:52:25 -05:00
remote-testsvn.c
remote.c
remote.h
replace-object.c
replace-object.h
repository.c trace2: create new combined trace facility 2019-02-05 15:52:25 -05:00
repository.h trace2: create new combined trace facility 2019-02-05 15:52:25 -05:00
rerere.c
rerere.h
resolve-undo.c
resolve-undo.h
revision.c
revision.h
run-command.c trace2: create new combined trace facility 2019-02-05 15:52:25 -05:00
run-command.h trace2: create new combined trace facility 2019-02-05 15:52:25 -05:00
send-pack.c
send-pack.h
sequencer.c trace2:data: add trace2 hook classification 2019-02-05 15:57:53 -05:00
sequencer.h
serve.c
serve.h
server-info.c
setup.c
sh-i18n--envsubst.c trace2: create new combined trace facility 2019-02-05 15:52:25 -05:00
sha1-array.c
sha1-array.h
sha1-file.c gvfs:trace2:data: add trace2 tracing around read_object_process 2019-02-05 16:15:46 -05:00
sha1-lookup.c
sha1-lookup.h
sha1-name.c
sha1dc_git.c
sha1dc_git.h
shallow.c
shell.c
shortlog.h
sideband.c
sideband.h
sigchain.c
sigchain.h
split-index.c
split-index.h
strbuf.c
strbuf.h
streaming.c
streaming.h
string-list.c
string-list.h
sub-process.c trace2:data: add trace2 sub-process classification 2019-02-05 15:57:52 -05:00
sub-process.h
submodule-config.c
submodule-config.h
submodule.c trace2: create new combined trace facility 2019-02-05 15:52:25 -05:00
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: create new combined trace facility 2019-02-05 15:52:25 -05:00
trace2.h trace2: collect Windows-specific process information 2019-02-05 15:57:45 -05:00
trailer.c
trailer.h
transport-helper.c trace2:data: add trace2 transport child classification 2019-02-05 15:57:53 -05:00
transport-internal.h
transport.c trace2:data: add trace2 hook classification 2019-02-05 15:57:53 -05:00
transport.h
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
unpack-trees.h
upload-pack.c
upload-pack.h
url.c
url.h
urlmatch.c
urlmatch.h
usage.c trace2: create new combined trace facility 2019-02-05 15:52:25 -05:00
userdiff.c
userdiff.h
utf8.c
utf8.h
varint.c
varint.h
version.c
version.h
versioncmp.c
virtualfilesystem.c gvfs:trace2:data: add vfs stats 2019-02-05 16:20:59 -05:00
virtualfilesystem.h
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-deserialize.c status: fixup deserialize for cocci 2019-03-27 11:26:04 -04:00
wt-status-serialize.c gvfs:trace2:data: status serialization 2019-02-05 16:20:59 -05:00
wt-status.c DROPME: trace2:status: use the_repository rather than s->repo 2019-02-05 16:13:37 -05:00
wt-status.h gvfs:trace2:data: status deserialization information 2019-02-05 16:20:15 -05:00
xdiff-interface.c
xdiff-interface.h
zlib.c

README.md

Git for Windows

Build Status (Windows/macOS/Linux) Build Status (core.autocrlf=true) Join the chat at https://gitter.im/git-for-windows/git

This is Git for Windows, the Windows port of Git.

The Git for Windows project is run using a governance model. If you encounter problems, you can report them as GitHub issues, discuss them on Git for Windows' Google Group, and contribute bug fixes.

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 core 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 core git mailing list is plain text (no HTML!).

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