From 3b2f5086bcaebddef2093bf61e9cb0a75c526059 Mon Sep 17 00:00:00 2001 From: git Date: Sun, 12 Sep 2010 16:43:31 -0700 Subject: [PATCH 001/591] Initial Commit --- Home.md | 1 + 1 file changed, 1 insertion(+) create mode 100644 Home.md diff --git a/Home.md b/Home.md new file mode 100644 index 00000000000000..3d4eeb7e2d426f --- /dev/null +++ b/Home.md @@ -0,0 +1 @@ +Welcome to the git wiki! \ No newline at end of file From 3a45e17cebd68c19e3dff62293d8efb1ca21c501 Mon Sep 17 00:00:00 2001 From: git Date: Sun, 12 Sep 2010 16:43:31 -0700 Subject: [PATCH 002/591] Migrated from home v1 --- Home.md => Home.textile | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename Home.md => Home.textile (100%) diff --git a/Home.md b/Home.textile similarity index 100% rename from Home.md rename to Home.textile From f1e7e2e8b24e789864ad133b9ee58377e21d867e Mon Sep 17 00:00:00 2001 From: ncqrs Date: Sun, 12 Sep 2010 16:43:33 -0700 Subject: [PATCH 003/591] Migrated from home v2 --- Home.textile | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/Home.textile b/Home.textile index 3d4eeb7e2d426f..648b890668036c 100644 --- a/Home.textile +++ b/Home.textile @@ -1 +1,10 @@ -Welcome to the git wiki! \ No newline at end of file +h2. Ncqrs Dev + +* "Home":http://ncqrs.org/ +* "Reference documentation": http://ncqrs.org/reference/ +* "Bug reports and patches":http://github.com/ncqrs/framework/issues +* "Development mailing list":http://groups.google.com/group/ncqrs-dev + +h2. Ncqrs suggested readings + +* "Getting started":http://ncqrs.org/getting-started/ \ No newline at end of file From e00a0080ec0c3b83faae27cfa323a60a89a6b656 Mon Sep 17 00:00:00 2001 From: ncqrs Date: Sun, 12 Sep 2010 16:43:34 -0700 Subject: [PATCH 004/591] Migrated from home v3 --- Home.textile | 11 +---------- 1 file changed, 1 insertion(+), 10 deletions(-) diff --git a/Home.textile b/Home.textile index 648b890668036c..3d4eeb7e2d426f 100644 --- a/Home.textile +++ b/Home.textile @@ -1,10 +1 @@ -h2. Ncqrs Dev - -* "Home":http://ncqrs.org/ -* "Reference documentation": http://ncqrs.org/reference/ -* "Bug reports and patches":http://github.com/ncqrs/framework/issues -* "Development mailing list":http://groups.google.com/group/ncqrs-dev - -h2. Ncqrs suggested readings - -* "Getting started":http://ncqrs.org/getting-started/ \ No newline at end of file +Welcome to the git wiki! \ No newline at end of file From 909832b3cf995026f558e42de4a12d9892951348 Mon Sep 17 00:00:00 2001 From: hvoigt Date: Wed, 23 May 2012 09:55:41 -0700 Subject: [PATCH 005/591] Updated Home (textile => mediawiki) --- Home.textile | 1 - Please-go-to.mediawiki | 3 +++ 2 files changed, 3 insertions(+), 1 deletion(-) delete mode 100644 Home.textile create mode 100644 Please-go-to.mediawiki diff --git a/Home.textile b/Home.textile deleted file mode 100644 index 3d4eeb7e2d426f..00000000000000 --- a/Home.textile +++ /dev/null @@ -1 +0,0 @@ -Welcome to the git wiki! \ No newline at end of file diff --git a/Please-go-to.mediawiki b/Please-go-to.mediawiki new file mode 100644 index 00000000000000..c1ade5b1051e29 --- /dev/null +++ b/Please-go-to.mediawiki @@ -0,0 +1,3 @@ +[[https://github.com/msysgit/msysgit/wiki]] + +for our wiki. \ No newline at end of file From 40427fb76ed03e360439c3d053a40b71d79b3c21 Mon Sep 17 00:00:00 2001 From: hvoigt Date: Wed, 23 May 2012 09:56:19 -0700 Subject: [PATCH 006/591] Updated Please go to (mediawiki) --- Please-go-to.mediawiki => Home.mediawiki | 2 ++ 1 file changed, 2 insertions(+) rename Please-go-to.mediawiki => Home.mediawiki (80%) diff --git a/Please-go-to.mediawiki b/Home.mediawiki similarity index 80% rename from Please-go-to.mediawiki rename to Home.mediawiki index c1ade5b1051e29..ce97e3af2efc42 100644 --- a/Please-go-to.mediawiki +++ b/Home.mediawiki @@ -1,3 +1,5 @@ +Please go to + [[https://github.com/msysgit/msysgit/wiki]] for our wiki. \ No newline at end of file From 7c0e950696ce9f770b5ce76027f1facc4987dca1 Mon Sep 17 00:00:00 2001 From: dscho Date: Tue, 14 Oct 2014 11:31:26 -0700 Subject: [PATCH 007/591] First frequently asked question --- FAQ.md | 3 +++ 1 file changed, 3 insertions(+) create mode 100644 FAQ.md diff --git a/FAQ.md b/FAQ.md new file mode 100644 index 00000000000000..fb65b6cc83a33e --- /dev/null +++ b/FAQ.md @@ -0,0 +1,3 @@ +## What is the relationship between *Git for Windows* and *msysGit*? + +*Git for Windows* used to be developed using the development environment called "msysGit", but roughly coinciding with Git 2.1, msysGit was superseded by a new development environment: the [Git for Windows SDK](https://github.com/git-for-windows/sdk). From 47c0b1bfd211f9723004c292aaeb8606b8ed15e8 Mon Sep 17 00:00:00 2001 From: dscho Date: Tue, 14 Oct 2014 11:35:22 -0700 Subject: [PATCH 008/591] Copy from msysGit's wiki --- Issue-reporting-guidelines.md | 10 ++++++++++ 1 file changed, 10 insertions(+) create mode 100644 Issue-reporting-guidelines.md diff --git a/Issue-reporting-guidelines.md b/Issue-reporting-guidelines.md new file mode 100644 index 00000000000000..880fb9e9e8d0f7 --- /dev/null +++ b/Issue-reporting-guidelines.md @@ -0,0 +1,10 @@ +* Search the existing open and closed issues. Maybe the bug was already reported? +* Include the output of git --version and the Windows version. In case the issue might depend on the server include its git version and OS version also. +* Properly describe your issue. If you spend 30 seconds writing the report, do expect that others will spend exactly the same amount on trying to resolve it. +* Include a minimal working example using the codeblock delimiters from Github Markdown. +* If your issue stems from a particular repository include its URL. If the repository is proprietary try to create a public test repository showing the same issue. +* Be prepared to test fixes! +* Be polite. You are asking highly competent software developers for help, for free, so you might want to avoid treating them as if they were a commodity and at your free disposal. +* An example for an outstanding report can be found [https://github.com/msysgit/msysgit/issues/206#issuecomment-44574988 here]. You may want to imitate the level of detail and time and effort put into that report, to show your appreciation for the help you hope to receive. +* For further inspiration, read reports that were resolved successfully, http://stackoverflow.com/questions/how-to-ask and http://whathaveyoutried.com/. + From 78162c76c98aa6d236d5be7d66e80f3aa2f209c5 Mon Sep 17 00:00:00 2001 From: dscho Date: Tue, 14 Oct 2014 12:44:19 -0700 Subject: [PATCH 009/591] Initial stab. Contributions welcome. --- How-to-participate.md | 15 +++++++++++++++ 1 file changed, 15 insertions(+) create mode 100644 How-to-participate.md diff --git a/How-to-participate.md b/How-to-participate.md new file mode 100644 index 00000000000000..51eac4fbb05a28 --- /dev/null +++ b/How-to-participate.md @@ -0,0 +1,15 @@ +There are several ways to participate in the Git for Windows project: + +# Help users + +On [the mailing list](http://groups.google.com/group/git-for-windows) or on [the issue tracker](https://github.com/git-for-windows/git/issues), help is always welcome. + +# Add documentation + +A lot of documentation wants to be written, still. A good place is [the Git for Windows wiki](https://github.com/git-for-windows/git/wiki). Tutorials, step by step instructions and general background information, etc. + +# Fix bugs or add features in the Git code itself + +Download [the SDK](http://git-for-windows.github.io/#download-sdk) and build Git. + +TODO: mention good practices to develop using Eclipse, MSVC, command-line, gdb, test suite (`set -x` and similar tricks) From 318b020aaf53cf8273fb9667707d127eeb010e8a Mon Sep 17 00:00:00 2001 From: dscho Date: Tue, 14 Oct 2014 12:48:01 -0700 Subject: [PATCH 010/591] Prepare for the switch from msysGit to Git for Windows SDK. --- Home.mediawiki | 6 ++---- 1 file changed, 2 insertions(+), 4 deletions(-) diff --git a/Home.mediawiki b/Home.mediawiki index ce97e3af2efc42..b720598f0dcee7 100644 --- a/Home.mediawiki +++ b/Home.mediawiki @@ -1,5 +1,3 @@ -Please go to +This is the Git for Windows wiki. It looks more technical [our home page](https://git-for-windows.github.io/), because it is the place where you can contribute to the documentation about Git for Windows. -[[https://github.com/msysgit/msysgit/wiki]] - -for our wiki. \ No newline at end of file +If you need inspiration what you could write about: document your common work flows. Write a tutorial how to start coding Git for Windows, how to run the test suite. Write a tutorial how to debug a failing test. Write about something you would have wished you had known about Git for Windows a long time ago. \ No newline at end of file From fda592492dcce8642ada0dde601e9c90517371c1 Mon Sep 17 00:00:00 2001 From: dscho Date: Tue, 14 Oct 2014 12:52:36 -0700 Subject: [PATCH 011/591] Touchups --- Issue-reporting-guidelines.md | 11 +++++------ 1 file changed, 5 insertions(+), 6 deletions(-) diff --git a/Issue-reporting-guidelines.md b/Issue-reporting-guidelines.md index 880fb9e9e8d0f7..b17d35107b0fc7 100644 --- a/Issue-reporting-guidelines.md +++ b/Issue-reporting-guidelines.md @@ -1,10 +1,9 @@ -* Search the existing open and closed issues. Maybe the bug was already reported? +* Search the existing [open](https://github.com/git-for-windows/git/issues?q=is%3Aopen) and [closed](https://github.com/git-for-windows/git/issues?q=is%3Aclosed) issues. Maybe the bug was already reported? * Include the output of git --version and the Windows version. In case the issue might depend on the server include its git version and OS version also. -* Properly describe your issue. If you spend 30 seconds writing the report, do expect that others will spend exactly the same amount on trying to resolve it. +* Describe your issue properly. If you spend 30 seconds throwing out a sloppy report, do expect that others will spend exactly the same amount on trying to resolve it. * Include a minimal working example using the codeblock delimiters from Github Markdown. * If your issue stems from a particular repository include its URL. If the repository is proprietary try to create a public test repository showing the same issue. * Be prepared to test fixes! -* Be polite. You are asking highly competent software developers for help, for free, so you might want to avoid treating them as if they were a commodity and at your free disposal. -* An example for an outstanding report can be found [https://github.com/msysgit/msysgit/issues/206#issuecomment-44574988 here]. You may want to imitate the level of detail and time and effort put into that report, to show your appreciation for the help you hope to receive. -* For further inspiration, read reports that were resolved successfully, http://stackoverflow.com/questions/how-to-ask and http://whathaveyoutried.com/. - +* Be polite. You are asking highly competent software developers for help, for free, so you might want to avoid treating them as if they were a commodity or at your free disposal. +* An example for an outstanding report can be found [here](https://github.com/msysgit/msysgit/issues/206#issuecomment-44574988). You may want to imitate the level of detail. +* For further inspiration, read reports that were resolved successfully, http://stackoverflow.com/questions/how-to-ask and http://whathaveyoutried.com/. \ No newline at end of file From d847764a2d0d1f0754372c42f7bb701522d771ee Mon Sep 17 00:00:00 2001 From: dscho Date: Tue, 14 Oct 2014 13:36:21 -0700 Subject: [PATCH 012/591] fix markup, grammar --- Home.mediawiki => Home.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) rename Home.mediawiki => Home.md (59%) diff --git a/Home.mediawiki b/Home.md similarity index 59% rename from Home.mediawiki rename to Home.md index b720598f0dcee7..b03fe398aa7250 100644 --- a/Home.mediawiki +++ b/Home.md @@ -1,3 +1,3 @@ -This is the Git for Windows wiki. It looks more technical [our home page](https://git-for-windows.github.io/), because it is the place where you can contribute to the documentation about Git for Windows. +This is the Git for Windows wiki. It looks more technical than [our home page](https://git-for-windows.github.io/) because it is the place where you can contribute to the documentation about Git for Windows. If you need inspiration what you could write about: document your common work flows. Write a tutorial how to start coding Git for Windows, how to run the test suite. Write a tutorial how to debug a failing test. Write about something you would have wished you had known about Git for Windows a long time ago. \ No newline at end of file From 7ada844d13cbec14ee3583af8b56344192172c4f Mon Sep 17 00:00:00 2001 From: dscho Date: Tue, 14 Oct 2014 13:39:20 -0700 Subject: [PATCH 013/591] Add stub --- Package-management.md | 13 +++++++++++++ 1 file changed, 13 insertions(+) create mode 100644 Package-management.md diff --git a/Package-management.md b/Package-management.md new file mode 100644 index 00000000000000..2ef44be32eba3c --- /dev/null +++ b/Package-management.md @@ -0,0 +1,13 @@ +TODO: explain what `mingw-get` is + +# How to use `mingw-get` + +## Install/upgrade packages + +# Technical details + +## Repository structure + +## Bintray + +## How to upload new versions (Git for Windows core developers only) \ No newline at end of file From bd4c7a98358f03039135d51a4fb3fcfeb4e030d0 Mon Sep 17 00:00:00 2001 From: dscho Date: Wed, 15 Oct 2014 08:47:45 -0700 Subject: [PATCH 014/591] Add more placeholders --- Package-management.md | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/Package-management.md b/Package-management.md index 2ef44be32eba3c..681dceb6eaa40f 100644 --- a/Package-management.md +++ b/Package-management.md @@ -10,4 +10,10 @@ TODO: explain what `mingw-get` is ## Bintray +## Using `mgwport` + +### Introduction: the `sdk-packages` project + +### Mgwport parses the filename and infers the package name, version and release from it. + ## How to upload new versions (Git for Windows core developers only) \ No newline at end of file From b5cbb38653e509485765d925d42c25343c456929 Mon Sep 17 00:00:00 2001 From: t-b Date: Thu, 16 Oct 2014 04:43:00 -0700 Subject: [PATCH 015/591] Updated Package management (markdown) --- Package-management.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Package-management.md b/Package-management.md index 681dceb6eaa40f..885cb4e19b150e 100644 --- a/Package-management.md +++ b/Package-management.md @@ -11,7 +11,7 @@ TODO: explain what `mingw-get` is ## Bintray ## Using `mgwport` - +Hardcore users might want to have a look at [mp](https://gist.github.com/t-b/7e7af6236e860ca6309a) which is a convenience wrapper for mgwport. ### Introduction: the `sdk-packages` project ### Mgwport parses the filename and infers the package name, version and release from it. From bf3769e7adff5965c40a6f0f185502e8c3acd422 Mon Sep 17 00:00:00 2001 From: dscho Date: Thu, 19 Feb 2015 12:38:20 +0100 Subject: [PATCH 016/591] We will switch to MSys2, actually --- Package-management.md | 12 ++++-------- 1 file changed, 4 insertions(+), 8 deletions(-) diff --git a/Package-management.md b/Package-management.md index 885cb4e19b150e..cf22d640e5a89e 100644 --- a/Package-management.md +++ b/Package-management.md @@ -1,6 +1,6 @@ -TODO: explain what `mingw-get` is +TODO: explain what `pacman` is -# How to use `mingw-get` +# How to use `pacman` ## Install/upgrade packages @@ -10,10 +10,6 @@ TODO: explain what `mingw-get` is ## Bintray -## Using `mgwport` -Hardcore users might want to have a look at [mp](https://gist.github.com/t-b/7e7af6236e860ca6309a) which is a convenience wrapper for mgwport. -### Introduction: the `sdk-packages` project +## How to upload new versions (Git for Windows core developers only) -### Mgwport parses the filename and infers the package name, version and release from it. - -## How to upload new versions (Git for Windows core developers only) \ No newline at end of file +TODO: explain how to use `makepkg`, `makepkg-mingw` and `repo-add` \ No newline at end of file From bb408a01fb8426a06f4dcd2f713c702ae540651c Mon Sep 17 00:00:00 2001 From: dscho Date: Thu, 19 Feb 2015 14:11:55 +0100 Subject: [PATCH 017/591] Explain how to use `pacman`, `makepkg` and `makepkg-mingw` --- Package-management.md | 60 +++++++++++++++++++++++++++++++++++++++++-- 1 file changed, 58 insertions(+), 2 deletions(-) diff --git a/Package-management.md b/Package-management.md index cf22d640e5a89e..c9a46df3d13432 100644 --- a/Package-management.md +++ b/Package-management.md @@ -1,15 +1,71 @@ -TODO: explain what `pacman` is +Modern software development relies heavily on a way to manage dependencies, i.e. to keep track of required software libraries and their versions. Examples are `apt-get` for Linux, `homebrew` for MacOSX, `Maven` for Java and `pip` for Python. + +Git for Windows is based on [MSys2](https://msys2.github.io/) which bundles Arch Linux' [Pacman](https://wiki.archlinux.org/index.php/Pacman) tool for dependency management. # How to use `pacman` +There is a `man` page for `pacman` and the tool also sports a `--help` option. These resources are recommended to address questions not covered by the following, brief descriptions. + ## Install/upgrade packages +To install a package, run + +```bash +pacman -S +``` + +To ensure that the newest package version is installed, it is recommended to pass the `-y` option, too, which asks Pacman to download the newest package list: + +```bash +pacman -Sy +``` + +## Remove packages + +```bash +pacman -R +``` + +## List packages + +To list the installed packages, call + +```bash +pacman -Q +``` + +To list the contents of a package, call + +```bash +pacman -Ql +``` + # Technical details ## Repository structure +TBD + ## Bintray +TBD + +## Rebuild packages + +To build MSys packages, you need to start the `MSys` shell (which sets `MSYSTEM=MSYS` before running the Bash), clone the [`MSYS2-packages`](https://github.com/git-for-windows/MSYS2-packages) repository (recommended location: `/usr/src/MSYS2-packages`), `cd` to the appropriate subdirectory and call + +```bash +makepkg -s +``` + +(The `-s` flag tells `makepkg` that it should install dependencies automatically as needed) + +To build MinGW packages, you need to start the appropriate `MinGW` shell (32-bit or 64-bit – this sets `MSYSTEM=MINGW32` or `MSYSTEM=MINGW64` respectively), clone the [`MINGW-packages`](https://github.com/git-for-windows/MINGW-packages) repository (recommended location: `/usr/src/MINGW-packages`), `cd` to the appropriate subdirectory and call + +```bash +makepkg-mingw -s +``` + ## How to upload new versions (Git for Windows core developers only) -TODO: explain how to use `makepkg`, `makepkg-mingw` and `repo-add` \ No newline at end of file +TODO: explain how to use `repo-add` \ No newline at end of file From 6a32590ced996532c9a8c9c434fc3b5b100b0235 Mon Sep 17 00:00:00 2001 From: dscho Date: Thu, 19 Feb 2015 14:52:43 +0100 Subject: [PATCH 018/591] Document how to rebuild msys-2.0.dll and bash.exe --- Package-management.md | 20 ++++++++++++++------ 1 file changed, 14 insertions(+), 6 deletions(-) diff --git a/Package-management.md b/Package-management.md index c9a46df3d13432..d31c18e20ddd2b 100644 --- a/Package-management.md +++ b/Package-management.md @@ -52,20 +52,28 @@ TBD ## Rebuild packages -To build MSys packages, you need to start the `MSys` shell (which sets `MSYSTEM=MSYS` before running the Bash), clone the [`MSYS2-packages`](https://github.com/git-for-windows/MSYS2-packages) repository (recommended location: `/usr/src/MSYS2-packages`), `cd` to the appropriate subdirectory and call +To build MinGW packages, you need to start the appropriate `MinGW` shell (32-bit or 64-bit – this sets `MSYSTEM=MINGW32` or `MSYSTEM=MINGW64` respectively), clone the [`MINGW-packages`](https://github.com/git-for-windows/MINGW-packages) repository (recommended location: `/usr/src/MINGW-packages`), `cd` to the appropriate subdirectory and call ```bash -makepkg -s +makepkg-mingw -s ``` - + (The `-s` flag tells `makepkg` that it should install dependencies automatically as needed) -To build MinGW packages, you need to start the appropriate `MinGW` shell (32-bit or 64-bit – this sets `MSYSTEM=MINGW32` or `MSYSTEM=MINGW64` respectively), clone the [`MINGW-packages`](https://github.com/git-for-windows/MINGW-packages) repository (recommended location: `/usr/src/MINGW-packages`), `cd` to the appropriate subdirectory and call +To build MSys packages, you need to start the `MSys` shell (which sets `MSYSTEM=MSYS` before running the Bash), clone the [`MSYS2-packages`](https://github.com/git-for-windows/MSYS2-packages) repository (recommended location: `/usr/src/MSYS2-packages`), `cd` to the appropriate subdirectory and call ```bash -makepkg-mingw -s +makepkg -s ``` - + +To rebuild the `msys2-runtime` (i.e. `msys-2.0.dll`), you will need to have a *second* MSys2 installation and quit all applications from the first MSys2 installation. In the second installation, as above, start the `MSys` shell and clone `MSYS2-packages` to `/usr/src/`. + +Inside the `msys2-runtime` subdirectory, you need to use `makepkg -s` *for the initial build*. + +For subsequent builds, after modifying the source files in `src/msys2-runtime/winsup/cygwin/` you can switch to `src/build--pc-msys/-pc-msys/winsup/cygwin` and type `make`. This will generate an `msys0.dll` file in the latter directory that you can then copy to the first MSys2 installation to test. + +The process to rebuild the `Bash` is very similar to the `msys2-runtime` one; You will just need to work in the `src/bash-/` subdirectory of `/usr/src/MSYS2-packages/bash/` (both the sources and the generated `bash.exe` live there). + ## How to upload new versions (Git for Windows core developers only) TODO: explain how to use `repo-add` \ No newline at end of file From e7c3e4f8a655489d8afae42b06474f9c3ca37681 Mon Sep 17 00:00:00 2001 From: dscho Date: Thu, 19 Feb 2015 14:54:13 +0100 Subject: [PATCH 019/591] Reorder sections (it will be much more interesting to the occasional contributor to learn how to rebuild msys-2.0.dll than how we package and upload new package versions) --- Package-management.md | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/Package-management.md b/Package-management.md index d31c18e20ddd2b..0dbe6ee212803e 100644 --- a/Package-management.md +++ b/Package-management.md @@ -42,14 +42,6 @@ pacman -Ql # Technical details -## Repository structure - -TBD - -## Bintray - -TBD - ## Rebuild packages To build MinGW packages, you need to start the appropriate `MinGW` shell (32-bit or 64-bit – this sets `MSYSTEM=MINGW32` or `MSYSTEM=MINGW64` respectively), clone the [`MINGW-packages`](https://github.com/git-for-windows/MINGW-packages) repository (recommended location: `/usr/src/MINGW-packages`), `cd` to the appropriate subdirectory and call @@ -74,6 +66,14 @@ For subsequent builds, after modifying the source files in `src/msys2-runtime/wi The process to rebuild the `Bash` is very similar to the `msys2-runtime` one; You will just need to work in the `src/bash-/` subdirectory of `/usr/src/MSYS2-packages/bash/` (both the sources and the generated `bash.exe` live there). +## Repository structure + +TBD + +## Bintray + +TBD + ## How to upload new versions (Git for Windows core developers only) TODO: explain how to use `repo-add` \ No newline at end of file From 1128eb2e9dca8e193a3a65940b537ff198826a9f Mon Sep 17 00:00:00 2001 From: dscho Date: Sun, 22 Feb 2015 12:36:28 +0100 Subject: [PATCH 020/591] Mention how to install CPAN packages --- Package-management.md | 14 ++++++++++++++ 1 file changed, 14 insertions(+) diff --git a/Package-management.md b/Package-management.md index 0dbe6ee212803e..1a4b861d48cf62 100644 --- a/Package-management.md +++ b/Package-management.md @@ -66,6 +66,20 @@ For subsequent builds, after modifying the source files in `src/msys2-runtime/wi The process to rebuild the `Bash` is very similar to the `msys2-runtime` one; You will just need to work in the `src/bash-/` subdirectory of `/usr/src/MSYS2-packages/bash/` (both the sources and the generated `bash.exe` live there). +## Perl package management + +Perl packages are managed outside of the `pacman` realm, but instead with [CPAN](http://www.cpan.org/): + +```bash +perl -MCPAN -e 'install ' +``` + +CPAN also offers an interactive shell: + +```bash +perl -MCPAN -e shell +``` + ## Repository structure TBD From b6efb65d5e0ed2040bcb4e6e85d8b11117570890 Mon Sep 17 00:00:00 2001 From: dscho Date: Sun, 22 Feb 2015 13:09:24 +0100 Subject: [PATCH 021/591] Finally start writing down the best practices developed during all those years trying to keep Git for Windows up-to-date with upstream Git --- Fixing-test-failures.md | 62 +++++++++++++++++++++++++++++++++++++++++ 1 file changed, 62 insertions(+) create mode 100644 Fixing-test-failures.md diff --git a/Fixing-test-failures.md b/Fixing-test-failures.md new file mode 100644 index 00000000000000..950a4e2b48c0b4 --- /dev/null +++ b/Fixing-test-failures.md @@ -0,0 +1,62 @@ +# Running tests + +Git's source code ships with a lot of [regression tests](http://en.wikipedia.org/wiki/Regression_testing). This gives us a pretty good indicator of the source code's health: if a regression test starts failing for a topic branch, it is safe to assume that there is some "room for improvement" in the changes introduced by said topic branch. + +It is a good practice to add a regression test when fixing bugs. Such a test not only illustrates what is going wrong (and lets other developers verify that there is indeed a bug that needs fixing), it also ensures that it is much harder to re-introduce that bug by mistake in the future: the regression tests would sound an alarm. + +## Running the complete test suite + +Git's test suite can be run in various ways: + +- by running `make test` in the directory where Git's sources were checked out (`/usr/src/git/` by default) +- by running `make` in the `t/` subdirectory of `/usr/src/git/` +- using Perl's `prove` test runner, by running `make prove` in the `t/` subdirectory of `/usr/src/git/` + +It can take quite a while to run the test suite. To help, Git allows to run those tests in parallel, e.g. by passing the `-j` flag to `make`: `make -j5` would run up to five tests in parallel. + +# Running individual tests + +When some tests fail, it is best to run them individually. This can be done using `make`, of course, a much better way is to run them via `sh`, though, allowing for more fine-grained control: + +- `sh t0001-*.sh -i` will run *t0001* and stop at the first failing test (as opposed to the default, to continue running the rest of the tests in the *t0001* test suite) +- `sh t0001-*.sh -v` will show the output of the programs called by the tests +- `sh t0001-*.sh -d` will keep the temporary directory in which the test was run, `trash directory.t0001-init/` (this is useful when comparing the output of tests between Git versions when the tests fail for one Git version but succeed for another). +- `sh -x t0001-*.sh` will print out the command-line of the programs before they are executed + +These options can be combined, too. + +## Further debugging techniques + +### Piping the output to a file + +Often there will be a ton of output and not all of that output is relevant to investigate test failures. In those cases, it makes sense to redirect the output to a file: + +```bash +sh -x t0001-*.sh -i -v 2>&1 | tee log.out +``` + +Alternatively, the output can be redirected to a pager: + +```bash +sh -x t0001-*.sh -i -v 2>&1 | less +``` + +To enable a quicker round-trip for running tests when running them repeatedly (typically changing the code a tad after each iteration), you can ask the `less` pager to fake key-presses just after starting. For example, the following command-line will always search for the first occurrence of the characters "ERROR:" in the output: + +```bash +sh -x t0001-*.sh -i -v 2>&1 | less +/ERROR: +``` + +### `set -x` + +The statement `set -x` in a shell script will turn on the execution trace (see the explanation of the `sh -x ...` invocation above), and `set +x` will turn it off. This is not only useful for adding debug output to the regression tests; It is also useful in the parts of Git that are still implemented as shell scripts (such as `git submodule`). + +For even more sophisticated debugging, the `set -x` statement can be triggered conditionally. The following example would turn on execution tracing only when the current commit name starts with *cafebabe*: + +```bash +case "$(git rev-parse HEAD 2> /dev/null)" in cafebabe*) set -x;; esac +``` + +### Tracing execution in Perl scripts + +Some parts of Git are implemented as Perl scripts. To trigger execution tracing similar to Bash's `set -x` statement, you can add the `-d:Trace` parameter to the shebang line (i.e. to the first line of the Perl script, which reads "#!/usr/bin/perl"). This requires the `Devel::Trace` Perl package to be installed, e.g. by calling `perl -MCPAN -e 'install Devel::Trace'` once. \ No newline at end of file From b42ef1fe251ad9c990229631246bc53f2449d9ee Mon Sep 17 00:00:00 2001 From: dscho Date: Sun, 22 Feb 2015 13:11:43 +0100 Subject: [PATCH 022/591] Rename the page (to a much better name) --- Fixing-test-failures.md => Running-Git's-regression-tests.md | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename Fixing-test-failures.md => Running-Git's-regression-tests.md (100%) diff --git a/Fixing-test-failures.md b/Running-Git's-regression-tests.md similarity index 100% rename from Fixing-test-failures.md rename to Running-Git's-regression-tests.md From 81b68c97c9d68b8fa9992600d8ae850686a0c28a Mon Sep 17 00:00:00 2001 From: dscho Date: Sun, 22 Feb 2015 13:21:35 +0100 Subject: [PATCH 023/591] Add `GIT_TRACE=1` technique. --- Running-Git's-regression-tests.md | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/Running-Git's-regression-tests.md b/Running-Git's-regression-tests.md index 950a4e2b48c0b4..a9e82296744d7d 100644 --- a/Running-Git's-regression-tests.md +++ b/Running-Git's-regression-tests.md @@ -59,4 +59,8 @@ case "$(git rev-parse HEAD 2> /dev/null)" in cafebabe*) set -x;; esac ### Tracing execution in Perl scripts -Some parts of Git are implemented as Perl scripts. To trigger execution tracing similar to Bash's `set -x` statement, you can add the `-d:Trace` parameter to the shebang line (i.e. to the first line of the Perl script, which reads "#!/usr/bin/perl"). This requires the `Devel::Trace` Perl package to be installed, e.g. by calling `perl -MCPAN -e 'install Devel::Trace'` once. \ No newline at end of file +Some parts of Git are implemented as Perl scripts. To trigger execution tracing similar to Bash's `set -x` statement, you can add the `-d:Trace` parameter to the shebang line (i.e. to the first line of the Perl script, which reads "#!/usr/bin/perl"). This requires the `Devel::Trace` Perl package to be installed, e.g. by calling `perl -MCPAN -e 'install Devel::Trace'` once. + +### `GIT_TRACE=1` + +When Git sees that the environment variable `GIT_TRACE` is set, it will print out an internal execution trace when Git wants to call external executables and builtins. This is extremely helpful in particular when debugging posix-to-windows mangling issues with the MSys2 runtime. All you do is to prefix the Git command to be executed in the test script with `GIT_TRACE=1 `, e.g. `GIT_TRACE=1 git difftool --extcmd "$2"`. \ No newline at end of file From c7d4f214fbddd8fb4825f31ad290e8d10ddd6dbd Mon Sep 17 00:00:00 2001 From: dscho Date: Sun, 22 Feb 2015 14:04:01 +0100 Subject: [PATCH 024/591] Add information about using interactive bash/gdb, plain old debug print statements. --- Running-Git's-regression-tests.md | 36 ++++++++++++++++++++++++++++++- 1 file changed, 35 insertions(+), 1 deletion(-) diff --git a/Running-Git's-regression-tests.md b/Running-Git's-regression-tests.md index a9e82296744d7d..b8e7dba13ded55 100644 --- a/Running-Git's-regression-tests.md +++ b/Running-Git's-regression-tests.md @@ -63,4 +63,38 @@ Some parts of Git are implemented as Perl scripts. To trigger execution tracing ### `GIT_TRACE=1` -When Git sees that the environment variable `GIT_TRACE` is set, it will print out an internal execution trace when Git wants to call external executables and builtins. This is extremely helpful in particular when debugging posix-to-windows mangling issues with the MSys2 runtime. All you do is to prefix the Git command to be executed in the test script with `GIT_TRACE=1 `, e.g. `GIT_TRACE=1 git difftool --extcmd "$2"`. \ No newline at end of file +When Git sees that the environment variable `GIT_TRACE` is set, it will print out an internal execution trace when Git wants to call external executables and builtins. This is extremely helpful in particular when debugging posix-to-windows mangling issues with the MSys2 runtime. All you do is to prefix the Git command to be executed in the test script with `GIT_TRACE=1 `, e.g. `GIT_TRACE=1 git difftool --extcmd "$2"`. + +### Interactive Bash/GDB + +Sometimes it is a pretty interesting option to investigate an intermediate state of a working directory in the middle of a test regression by starting an interactive shell right at that moment. There is just *one* problem with inserting `bash &&` into the test's code: Git automatically redirects `stdin`/`stdout`/`stderr`. This needs to be switched off explicitly by editing the `test_eval_` function in `t/test-lib.sh`, deleting all those redirections. + +To run the GNU debugger (`gdb`), these redirections need to be disabled, too, and in addition it is a good idea to recompile the entire Git sources after removing the `-O2` flag from the `CFLAGS` in the `Makefile`: For years, gdb has problems to identify exact code locations when the code was compiled with optimizations. + +### Plain old debug print statements + +When all else fails, and in particular when no interactive debugger is available, the only remaining debugging technique is to output print statements, i.e. insert `fprintf(stderr, ...);` (or conveniently `error(...)`) into C code, `echo ... >&2` into shell code, `print(STDERR, ...);` into Perl code etc. + +It gets even trickier when there is no `stdout`/`stderr` available (e.g. when debugging issues with the "remote" side of a push/fetch), in which case the debug information should be written (appended) into a file. In C, you would do this via `{ FILE *f = fopen("C:\\log.out", "a"); fprintf(f, ...); fclose(f); }`, in shell via `echo ... >> /c/log.out` and in Perl via `{ my $fh = open(">>c:\\log.out"); print($fh ...); close($fh); }`. + +While it is a little cumbersome to add such debug print statements (after all, you typically have to rebuild the executables and run the tests from the top), there is also a big benefit to this technique over single-stepping: the debug output can be made conditional upon the particulars of the problem to be debugged. For example, instead of writing out information *every* time, say, `get_sha1_hex()` is called, it can be written out *only* the third time it is called with an SHA-1 beginning with two specific byte values. This technique can also be combined with single-stepping, by setting a breakpoint on that conditional debug output, saving a lot of time to get back to the same point after modifying and recompiling the source code. + +There exist even more problematic situations when working on Git for Windows, though: when trying to figure out issues in the MSys2 runtime, there might not be any `fprintf(...)` functionality available at that point of execution (yet). In this case, you need to revert to the plain Win32 API to write into a file: + +```c +... +#define WIN32_LEAN_AND_MEAN +#include +#undef ERROR +... +{ HANDLE h = CreateFile("C:\\log.out", FILE_APPEND_DATA, FILE_SHARE_READ, NULL, OPEN_ALWAYS, FILE_ATTRIBUTE_NORMAL, NULL); if (h) { +#undef DDD +#define DDD(str) WriteFile(h, str, strlen(str), NULL, 0); +DDD("Hello"); +DDD(...); +DDD("\n"); +CloseHandle(h); +} } +``` + +Of course, if it is possible to write to `stderr` instead, the code should use `HANDLE h = GetStdHandle(STD_ERROR_HANDLE);` instead of the `CreateFile()` call instead, and *not* close the handle... \ No newline at end of file From d2840d80f32d576bb57988cd2b595635c4cfda6b Mon Sep 17 00:00:00 2001 From: dscho Date: Mon, 23 Feb 2015 13:51:05 +0100 Subject: [PATCH 025/591] Document how to build stuff and things --- Building-Git.md | 40 ++++++++++++++++++++++++++++++++++++++++ 1 file changed, 40 insertions(+) create mode 100644 Building-Git.md diff --git a/Building-Git.md b/Building-Git.md new file mode 100644 index 00000000000000..7a14d2f000e546 --- /dev/null +++ b/Building-Git.md @@ -0,0 +1,40 @@ +We build Git for Windows using [MSys2](https://msys2.github.io/). + +As we are in the process of switching away from msysGit as our development environment, the following instructions are a little rough on the edges. This situation should become better over the next months. + +# Installing a build environment + +1. Install MSys2 from https://msys2.github.io/, into `C:/msys32` and `C:/msys64` (if you only want to build for one architecture, you can skip the other one). This will install three Shells into the Start Menu: the *MSys*, the *MinGW 32* and the *MinGW 64* Shell. To build Git, you should start the *MinGW* shell corresponding to the architecture of the installed MSys2. + +2. Add the Git for Windows-specific Pacman repository: insert the following lines into your `/etc/pacman.conf`, **before** the `[mingw]` line (it is important : +> [git-for-windows] +> Server = https://git-for-windows.github.io/pacman-repository/$arch +> SigLevel = Optional + +3. Update via Pacman: `pacman -Syu` (as the msys2-runtime gets updated, the *MSys Shell* needs to be restarted afterwards). + +# Build Git + +1. Install (MSys2) Git: `pacman -S git`. That Git is based on MSys2, i.e. it is *not* a MinGW Git. However, we need a working Git to check out the Git source, eh? :grinning: + +2. Clone Git: `cd /usr/src/ && git clone https://github.com/git-for-windows/git`. + +3. Install the Toolchain (gcc etc): `pacman -S mingw-w64--toolchain`, where `` is either `i686` or `x86-64`. + +4. Install Git's dependencies: `pacman -S python less openssh patch make perl-Error perl perl-Authen-SASL perl-libwww perl-MIME-tools perl-Net-SMTP-SSL perl-TermReadKey winpty-git mingw-w64--curl mingw-w64--expat mingw-w64--openssl mingw-w64--tcl` + +5. Temporarily: In /usr/src/git/, check out the `tentative-2.3.0` branch: `git remote add -f dscho https://github.com/dscho/git && git checkout -t dscho/tentative-2.3.0`. + +6. Build Git. Some dependencies might be missing, still, e.g. subversion, gettext, man, mingw-w64--gdb, mingw-w64--pcre, binutils or texinfo (these packages were installed manually before the first successful Git for Windows build). + +# Build the `msys2-⁠runtime` + +1. Install the MSys2 Toolchain: `pacman -⁠S gcc binutils make`. + +2. Clone the MSYS2-packages repository: `cd /usr/src && git clone https://github.com/git-for-windows/MSYS2-packages`. + +3. Temporarily: In MSYS2-packages, check out the `msys-runtime` branch: `git remote add -f dscho https://github.com/dscho/MSYS2-packages && git checkout -t dscho/msys-runtime`. + +4. Build the package: `makepkg -⁠s`. + +(You might need to call `pacman -S ca-certificates` to reinstall that package, it seems that it was not installed properly at least in one MSys2 32-bit setup.) \ No newline at end of file From fdf88729114a64f811419b153f5da1d5bdc93215 Mon Sep 17 00:00:00 2001 From: dscho Date: Mon, 23 Feb 2015 14:10:17 +0100 Subject: [PATCH 026/591] Oops. MSys2 spells x86_64 consistently with an underscore... --- Building-Git.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Building-Git.md b/Building-Git.md index 7a14d2f000e546..e4265cfd230494 100644 --- a/Building-Git.md +++ b/Building-Git.md @@ -19,7 +19,7 @@ As we are in the process of switching away from msysGit as our development envir 2. Clone Git: `cd /usr/src/ && git clone https://github.com/git-for-windows/git`. -3. Install the Toolchain (gcc etc): `pacman -S mingw-w64--toolchain`, where `` is either `i686` or `x86-64`. +3. Install the Toolchain (gcc etc): `pacman -S mingw-w64--toolchain`, where `` is either `i686` or `x86_64`. 4. Install Git's dependencies: `pacman -S python less openssh patch make perl-Error perl perl-Authen-SASL perl-libwww perl-MIME-tools perl-Net-SMTP-SSL perl-TermReadKey winpty-git mingw-w64--curl mingw-w64--expat mingw-w64--openssl mingw-w64--tcl` From 8a0700a090aefbcb66dbf103603f79a210900727 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=EB=A7=88=EB=88=84=EC=97=98?= Date: Mon, 23 Feb 2015 16:18:42 +0100 Subject: [PATCH 027/591] Added note about a MSYS2 issue for building git --- Building-Git.md | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/Building-Git.md b/Building-Git.md index e4265cfd230494..9b9e9566067661 100644 --- a/Building-Git.md +++ b/Building-Git.md @@ -27,6 +27,10 @@ As we are in the process of switching away from msysGit as our development envir 6. Build Git. Some dependencies might be missing, still, e.g. subversion, gettext, man, mingw-w64--gdb, mingw-w64--pcre, binutils or texinfo (these packages were installed manually before the first successful Git for Windows build). +*** + +_Note_: if you encounter messages like `39 [main] make 7628 child_info_fork::abort:...` while running make, follow the following MSYS2 [Issue](http://sourceforge.net/p/msys2/tickets/74/) post. + # Build the `msys2-⁠runtime` 1. Install the MSys2 Toolchain: `pacman -⁠S gcc binutils make`. From 662fc143d35a2b75dbbed8daa3a96e9c9ad75f7d Mon Sep 17 00:00:00 2001 From: dscho Date: Mon, 23 Feb 2015 18:50:30 +0100 Subject: [PATCH 028/591] Hint at the resolution of the `child_info_fork` issue --- Building-Git.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Building-Git.md b/Building-Git.md index 9b9e9566067661..f6bbe97df99b8e 100644 --- a/Building-Git.md +++ b/Building-Git.md @@ -29,7 +29,7 @@ As we are in the process of switching away from msysGit as our development envir *** -_Note_: if you encounter messages like `39 [main] make 7628 child_info_fork::abort:...` while running make, follow the following MSYS2 [Issue](http://sourceforge.net/p/msys2/tickets/74/) post. +_Note_: if you encounter messages like `39 [main] make 7628 child_info_fork::abort:...` while running make, follow the following MSYS2 [Issue](http://sourceforge.net/p/msys2/tickets/74/) post, in short: close all MSys2 windows and run the `autorebase.bat` script in the top-level MSys2 directory from a `cmd`. # Build the `msys2-⁠runtime` From 1e20aeb21282e254b6d3a9022d75896d66dc9c74 Mon Sep 17 00:00:00 2001 From: dscho Date: Mon, 23 Feb 2015 18:51:21 +0100 Subject: [PATCH 029/591] PCRE is now a confirmed dependency --- Building-Git.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/Building-Git.md b/Building-Git.md index f6bbe97df99b8e..9c0efe7fa7a9eb 100644 --- a/Building-Git.md +++ b/Building-Git.md @@ -21,11 +21,11 @@ As we are in the process of switching away from msysGit as our development envir 3. Install the Toolchain (gcc etc): `pacman -S mingw-w64--toolchain`, where `` is either `i686` or `x86_64`. -4. Install Git's dependencies: `pacman -S python less openssh patch make perl-Error perl perl-Authen-SASL perl-libwww perl-MIME-tools perl-Net-SMTP-SSL perl-TermReadKey winpty-git mingw-w64--curl mingw-w64--expat mingw-w64--openssl mingw-w64--tcl` +4. Install Git's dependencies: `pacman -S python less openssh patch make perl-Error perl perl-Authen-SASL perl-libwww perl-MIME-tools perl-Net-SMTP-SSL perl-TermReadKey winpty-git mingw-w64--curl mingw-w64--expat mingw-w64--openssl mingw-w64--tcl mingw-w64--pcre` 5. Temporarily: In /usr/src/git/, check out the `tentative-2.3.0` branch: `git remote add -f dscho https://github.com/dscho/git && git checkout -t dscho/tentative-2.3.0`. -6. Build Git. Some dependencies might be missing, still, e.g. subversion, gettext, man, mingw-w64--gdb, mingw-w64--pcre, binutils or texinfo (these packages were installed manually before the first successful Git for Windows build). +6. Build Git. Some dependencies might be missing, still, e.g. subversion, gettext, man, mingw-w64--gdb, binutils or texinfo (these packages were installed manually before the first successful Git for Windows build). *** From baf2e1346c8b816df0ad594b781e6a22ccd313da Mon Sep 17 00:00:00 2001 From: dscho Date: Tue, 24 Feb 2015 09:32:26 +0100 Subject: [PATCH 030/591] Note aboute MINGW32 packages --- Package-management.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/Package-management.md b/Package-management.md index 1a4b861d48cf62..d72e6290673ddf 100644 --- a/Package-management.md +++ b/Package-management.md @@ -52,6 +52,8 @@ makepkg-mingw -s (The `-s` flag tells `makepkg` that it should install dependencies automatically as needed) +Note: To compile 32-bit packages, you might need to set `MINGW_INSTALLS=mingw32` first. + To build MSys packages, you need to start the `MSys` shell (which sets `MSYSTEM=MSYS` before running the Bash), clone the [`MSYS2-packages`](https://github.com/git-for-windows/MSYS2-packages) repository (recommended location: `/usr/src/MSYS2-packages`), `cd` to the appropriate subdirectory and call ```bash From 270379ab5c7ebf0b024206423ccfc2868724be8b Mon Sep 17 00:00:00 2001 From: dscho Date: Tue, 24 Feb 2015 15:20:40 +0100 Subject: [PATCH 031/591] The 'tar' package is required to run t0024, t3513, t4116, t5000, t5001, t5002, t5004, t6041, t7800 and t9502. --- Building-Git.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Building-Git.md b/Building-Git.md index 9c0efe7fa7a9eb..98b7483c9128b6 100644 --- a/Building-Git.md +++ b/Building-Git.md @@ -21,7 +21,7 @@ As we are in the process of switching away from msysGit as our development envir 3. Install the Toolchain (gcc etc): `pacman -S mingw-w64--toolchain`, where `` is either `i686` or `x86_64`. -4. Install Git's dependencies: `pacman -S python less openssh patch make perl-Error perl perl-Authen-SASL perl-libwww perl-MIME-tools perl-Net-SMTP-SSL perl-TermReadKey winpty-git mingw-w64--curl mingw-w64--expat mingw-w64--openssl mingw-w64--tcl mingw-w64--pcre` +4. Install Git's dependencies: `pacman -S python less openssh patch make tar perl-Error perl perl-Authen-SASL perl-libwww perl-MIME-tools perl-Net-SMTP-SSL perl-TermReadKey winpty-git mingw-w64--curl mingw-w64--expat mingw-w64--openssl mingw-w64--tcl mingw-w64--pcre` 5. Temporarily: In /usr/src/git/, check out the `tentative-2.3.0` branch: `git remote add -f dscho https://github.com/dscho/git && git checkout -t dscho/tentative-2.3.0`. From 30db14974a5fb3c4efc571e0189ba83c4b6674f2 Mon Sep 17 00:00:00 2001 From: dscho Date: Tue, 24 Feb 2015 21:40:22 +0100 Subject: [PATCH 032/591] For some reason, MSys2's ca-certificates are not installed properly; they need to be reinstalled --- Building-Git.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Building-Git.md b/Building-Git.md index 98b7483c9128b6..28bef7b223e66f 100644 --- a/Building-Git.md +++ b/Building-Git.md @@ -21,7 +21,7 @@ As we are in the process of switching away from msysGit as our development envir 3. Install the Toolchain (gcc etc): `pacman -S mingw-w64--toolchain`, where `` is either `i686` or `x86_64`. -4. Install Git's dependencies: `pacman -S python less openssh patch make tar perl-Error perl perl-Authen-SASL perl-libwww perl-MIME-tools perl-Net-SMTP-SSL perl-TermReadKey winpty-git mingw-w64--curl mingw-w64--expat mingw-w64--openssl mingw-w64--tcl mingw-w64--pcre` +4. Install Git's dependencies: `pacman -S python less openssh patch make tar ca-certificates perl-Error perl perl-Authen-SASL perl-libwww perl-MIME-tools perl-Net-SMTP-SSL perl-TermReadKey winpty-git mingw-w64--curl mingw-w64--expat mingw-w64--openssl mingw-w64--tcl mingw-w64--pcre` 5. Temporarily: In /usr/src/git/, check out the `tentative-2.3.0` branch: `git remote add -f dscho https://github.com/dscho/git && git checkout -t dscho/tentative-2.3.0`. From 8be332d85bfd17a9207fb9afd8703d4eaf07a725 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=EB=A7=88=EB=88=84=EC=97=98?= Date: Wed, 25 Feb 2015 07:13:17 +0100 Subject: [PATCH 033/591] Updated name of temporary remote branch to update-to-2.3.0, correct me if that was a mistake. --- Building-Git.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Building-Git.md b/Building-Git.md index 28bef7b223e66f..83f24862f62072 100644 --- a/Building-Git.md +++ b/Building-Git.md @@ -23,7 +23,7 @@ As we are in the process of switching away from msysGit as our development envir 4. Install Git's dependencies: `pacman -S python less openssh patch make tar ca-certificates perl-Error perl perl-Authen-SASL perl-libwww perl-MIME-tools perl-Net-SMTP-SSL perl-TermReadKey winpty-git mingw-w64--curl mingw-w64--expat mingw-w64--openssl mingw-w64--tcl mingw-w64--pcre` -5. Temporarily: In /usr/src/git/, check out the `tentative-2.3.0` branch: `git remote add -f dscho https://github.com/dscho/git && git checkout -t dscho/tentative-2.3.0`. +5. Temporarily: In /usr/src/git/, check out the `update-to-2.3.0` branch: `git remote add -f dscho https://github.com/dscho/git && git checkout -t dscho/update-to-2.3.0`. 6. Build Git. Some dependencies might be missing, still, e.g. subversion, gettext, man, mingw-w64--gdb, binutils or texinfo (these packages were installed manually before the first successful Git for Windows build). From f0514ee79976169ec54532d0560eee5f05483ab6 Mon Sep 17 00:00:00 2001 From: dscho Date: Wed, 25 Feb 2015 08:43:17 +0100 Subject: [PATCH 034/591] diffutils are needed for the test suite: `cmp.exe` is called *a lot* --- Building-Git.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Building-Git.md b/Building-Git.md index 83f24862f62072..7c656dd5ccf162 100644 --- a/Building-Git.md +++ b/Building-Git.md @@ -21,7 +21,7 @@ As we are in the process of switching away from msysGit as our development envir 3. Install the Toolchain (gcc etc): `pacman -S mingw-w64--toolchain`, where `` is either `i686` or `x86_64`. -4. Install Git's dependencies: `pacman -S python less openssh patch make tar ca-certificates perl-Error perl perl-Authen-SASL perl-libwww perl-MIME-tools perl-Net-SMTP-SSL perl-TermReadKey winpty-git mingw-w64--curl mingw-w64--expat mingw-w64--openssl mingw-w64--tcl mingw-w64--pcre` +4. Install Git's dependencies: `pacman -S python less openssh patch make tar diffutils ca-certificates perl-Error perl perl-Authen-SASL perl-libwww perl-MIME-tools perl-Net-SMTP-SSL perl-TermReadKey winpty-git mingw-w64--curl mingw-w64--expat mingw-w64--openssl mingw-w64--tcl mingw-w64--pcre` 5. Temporarily: In /usr/src/git/, check out the `update-to-2.3.0` branch: `git remote add -f dscho https://github.com/dscho/git && git checkout -t dscho/update-to-2.3.0`. From a9584117d97fa56606a31facd7b1dc12b200fe70 Mon Sep 17 00:00:00 2001 From: dscho Date: Wed, 25 Feb 2015 10:51:02 +0100 Subject: [PATCH 035/591] Update instructions (we have a convenient SDK setup script now) --- Building-Git.md | 19 +++++-------------- 1 file changed, 5 insertions(+), 14 deletions(-) diff --git a/Building-Git.md b/Building-Git.md index 7c656dd5ccf162..4cdf46e170642c 100644 --- a/Building-Git.md +++ b/Building-Git.md @@ -6,26 +6,17 @@ As we are in the process of switching away from msysGit as our development envir 1. Install MSys2 from https://msys2.github.io/, into `C:/msys32` and `C:/msys64` (if you only want to build for one architecture, you can skip the other one). This will install three Shells into the Start Menu: the *MSys*, the *MinGW 32* and the *MinGW 64* Shell. To build Git, you should start the *MinGW* shell corresponding to the architecture of the installed MSys2. -2. Add the Git for Windows-specific Pacman repository: insert the following lines into your `/etc/pacman.conf`, **before** the `[mingw]` line (it is important : -> [git-for-windows] -> Server = https://git-for-windows.github.io/pacman-repository/$arch -> SigLevel = Optional - -3. Update via Pacman: `pacman -Syu` (as the msys2-runtime gets updated, the *MSys Shell* needs to be restarted afterwards). +2. Download and run [this file](https://raw.githubusercontent.com/git-for-windows/build-extra/master/setup-git-sdk.bat) in a `cmd` window in the top-level MSys2 directory (you need to close all MSys2 windows before that, so that the `msys-2.0.dll` file can be updated). # Build Git -1. Install (MSys2) Git: `pacman -S git`. That Git is based on MSys2, i.e. it is *not* a MinGW Git. However, we need a working Git to check out the Git source, eh? :grinning: - -2. Clone Git: `cd /usr/src/ && git clone https://github.com/git-for-windows/git`. - -3. Install the Toolchain (gcc etc): `pacman -S mingw-w64--toolchain`, where `` is either `i686` or `x86_64`. +1. Clone Git: `cd /usr/src/ && git clone https://github.com/git-for-windows/git`. -4. Install Git's dependencies: `pacman -S python less openssh patch make tar diffutils ca-certificates perl-Error perl perl-Authen-SASL perl-libwww perl-MIME-tools perl-Net-SMTP-SSL perl-TermReadKey winpty-git mingw-w64--curl mingw-w64--expat mingw-w64--openssl mingw-w64--tcl mingw-w64--pcre` +2. Temporarily: In /usr/src/git/, check out the `update-to-2.3.0` branch: `git remote add -f dscho https://github.com/dscho/git && git checkout -t dscho/update-to-2.3.0`. -5. Temporarily: In /usr/src/git/, check out the `update-to-2.3.0` branch: `git remote add -f dscho https://github.com/dscho/git && git checkout -t dscho/update-to-2.3.0`. +3. Build Git: `make`. -6. Build Git. Some dependencies might be missing, still, e.g. subversion, gettext, man, mingw-w64--gdb, binutils or texinfo (these packages were installed manually before the first successful Git for Windows build). +4. Run the test suite: `make test` *** From e15bbe65e6a7ccdcfc91090b740594fce6b4a59d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=EB=A7=88=EB=88=84=EC=97=98?= Date: Wed, 25 Feb 2015 18:57:58 +0100 Subject: [PATCH 036/591] changed build instruction to altered setup-git-sdk.bat --- Building-Git.md | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/Building-Git.md b/Building-Git.md index 4cdf46e170642c..9f197e7c376641 100644 --- a/Building-Git.md +++ b/Building-Git.md @@ -8,6 +8,12 @@ As we are in the process of switching away from msysGit as our development envir 2. Download and run [this file](https://raw.githubusercontent.com/git-for-windows/build-extra/master/setup-git-sdk.bat) in a `cmd` window in the top-level MSys2 directory (you need to close all MSys2 windows before that, so that the `msys-2.0.dll` file can be updated). +3. after you run the `setup-git-sdk.bat` the `msys2-runtime` got updated. Now it is time to fire up the *MinGW* shell and update the rest of the system and install the build dependencies. + +`pacman -Su --noconfirm` + +`pacman -S --noconfirm python less openssh patch make tar diffutils ca-certificates perl-Error perl perl-Authen-SASL perl-libwww perl-MIME-tools perl-Net-SMTP-SSL perl-TermReadKey winpty-git mingw-w64--curl mingw-w64--expat mingw-w64--openssl mingw-w64--tcl mingw-w64--pcre` + # Build Git 1. Clone Git: `cd /usr/src/ && git clone https://github.com/git-for-windows/git`. From 2909eacc33052f58c187fb7f0207111abb76b2cb Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=EB=A7=88=EB=88=84=EC=97=98?= Date: Wed, 25 Feb 2015 19:00:02 +0100 Subject: [PATCH 037/591] fixed typo --- Building-Git.md | 6 +----- 1 file changed, 1 insertion(+), 5 deletions(-) diff --git a/Building-Git.md b/Building-Git.md index 9f197e7c376641..d01d2187765a12 100644 --- a/Building-Git.md +++ b/Building-Git.md @@ -8,11 +8,7 @@ As we are in the process of switching away from msysGit as our development envir 2. Download and run [this file](https://raw.githubusercontent.com/git-for-windows/build-extra/master/setup-git-sdk.bat) in a `cmd` window in the top-level MSys2 directory (you need to close all MSys2 windows before that, so that the `msys-2.0.dll` file can be updated). -3. after you run the `setup-git-sdk.bat` the `msys2-runtime` got updated. Now it is time to fire up the *MinGW* shell and update the rest of the system and install the build dependencies. - -`pacman -Su --noconfirm` - -`pacman -S --noconfirm python less openssh patch make tar diffutils ca-certificates perl-Error perl perl-Authen-SASL perl-libwww perl-MIME-tools perl-Net-SMTP-SSL perl-TermReadKey winpty-git mingw-w64--curl mingw-w64--expat mingw-w64--openssl mingw-w64--tcl mingw-w64--pcre` +3. After you run the `setup-git-sdk.bat` the custom git-for-windows `msys2-runtime` got installed. Now it is time to fire up the *MinGW* shell and update the rest of the system and install the build dependencies. To update the system run `pacman -Su --noconfirm` and to install the dependencies run `pacman -S --noconfirm python less openssh patch make tar diffutils ca-certificates perl-Error perl perl-Authen-SASL perl-libwww perl-MIME-tools perl-Net-SMTP-SSL perl-TermReadKey winpty-git mingw-w64--curl mingw-w64--expat mingw-w64--openssl mingw-w64--tcl mingw-w64--pcre` # Build Git From db138a8f563d219e487d6cf2b7664534c263e1a4 Mon Sep 17 00:00:00 2001 From: Thomas Braun Date: Thu, 26 Feb 2015 00:48:42 +0100 Subject: [PATCH 038/591] Updated Building Git (markdown) --- Building-Git.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Building-Git.md b/Building-Git.md index d01d2187765a12..a1cd37068be6d1 100644 --- a/Building-Git.md +++ b/Building-Git.md @@ -8,7 +8,7 @@ As we are in the process of switching away from msysGit as our development envir 2. Download and run [this file](https://raw.githubusercontent.com/git-for-windows/build-extra/master/setup-git-sdk.bat) in a `cmd` window in the top-level MSys2 directory (you need to close all MSys2 windows before that, so that the `msys-2.0.dll` file can be updated). -3. After you run the `setup-git-sdk.bat` the custom git-for-windows `msys2-runtime` got installed. Now it is time to fire up the *MinGW* shell and update the rest of the system and install the build dependencies. To update the system run `pacman -Su --noconfirm` and to install the dependencies run `pacman -S --noconfirm python less openssh patch make tar diffutils ca-certificates perl-Error perl perl-Authen-SASL perl-libwww perl-MIME-tools perl-Net-SMTP-SSL perl-TermReadKey winpty-git mingw-w64--curl mingw-w64--expat mingw-w64--openssl mingw-w64--tcl mingw-w64--pcre` +3. After you run the `setup-git-sdk.bat` the custom git-for-windows `msys2-runtime` got installed. Now it is time to fire up the *MinGW* shell and update the rest of the system and install the build dependencies. To update the system run `pacman -Su --noconfirm` and to install the dependencies run `pacman -S --noconfirm python less openssh patch make tar diffutils ca-certificates perl-Error perl perl-Authen-SASL perl-libwww perl-MIME-tools perl-Net-SMTP-SSL perl-TermReadKey winpty-git mingw-w64--curl mingw-w64--expat mingw-w64--openssl mingw-w64--tcl mingw-w64--pcre`. is "i686" for the 32bit version. # Build Git From 9777fb7af6bef7ce1e63cd7e92e0aca9dcef80ca Mon Sep 17 00:00:00 2001 From: Thomas Braun Date: Thu, 26 Feb 2015 00:49:07 +0100 Subject: [PATCH 039/591] Updated Building Git (markdown) --- Building-Git.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Building-Git.md b/Building-Git.md index a1cd37068be6d1..9c221c420166c7 100644 --- a/Building-Git.md +++ b/Building-Git.md @@ -8,7 +8,7 @@ As we are in the process of switching away from msysGit as our development envir 2. Download and run [this file](https://raw.githubusercontent.com/git-for-windows/build-extra/master/setup-git-sdk.bat) in a `cmd` window in the top-level MSys2 directory (you need to close all MSys2 windows before that, so that the `msys-2.0.dll` file can be updated). -3. After you run the `setup-git-sdk.bat` the custom git-for-windows `msys2-runtime` got installed. Now it is time to fire up the *MinGW* shell and update the rest of the system and install the build dependencies. To update the system run `pacman -Su --noconfirm` and to install the dependencies run `pacman -S --noconfirm python less openssh patch make tar diffutils ca-certificates perl-Error perl perl-Authen-SASL perl-libwww perl-MIME-tools perl-Net-SMTP-SSL perl-TermReadKey winpty-git mingw-w64--curl mingw-w64--expat mingw-w64--openssl mingw-w64--tcl mingw-w64--pcre`. is "i686" for the 32bit version. +3. After you run the `setup-git-sdk.bat` the custom git-for-windows `msys2-runtime` got installed. Now it is time to fire up the *MinGW* shell and update the rest of the system and install the build dependencies. To update the system run `pacman -Su --noconfirm` and to install the dependencies run `pacman -S --noconfirm python less openssh patch make tar diffutils ca-certificates perl-Error perl perl-Authen-SASL perl-libwww perl-MIME-tools perl-Net-SMTP-SSL perl-TermReadKey winpty-git mingw-w64--curl mingw-w64--expat mingw-w64--openssl mingw-w64--tcl mingw-w64--pcre`. \ is "i686" for the 32bit version. # Build Git From df985ccdcc0ef733ba1a69675371d01fc13cc776 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=EB=A7=88=EB=88=84=EC=97=98?= Date: Thu, 26 Feb 2015 10:56:56 +0100 Subject: [PATCH 040/591] Updated instructions to reflect the install via shell script. I referenced my fork till the changes are merged. --- Building-Git.md | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/Building-Git.md b/Building-Git.md index 9c221c420166c7..987075a533de36 100644 --- a/Building-Git.md +++ b/Building-Git.md @@ -6,19 +6,19 @@ As we are in the process of switching away from msysGit as our development envir 1. Install MSys2 from https://msys2.github.io/, into `C:/msys32` and `C:/msys64` (if you only want to build for one architecture, you can skip the other one). This will install three Shells into the Start Menu: the *MSys*, the *MinGW 32* and the *MinGW 64* Shell. To build Git, you should start the *MinGW* shell corresponding to the architecture of the installed MSys2. -2. Download and run [this file](https://raw.githubusercontent.com/git-for-windows/build-extra/master/setup-git-sdk.bat) in a `cmd` window in the top-level MSys2 directory (you need to close all MSys2 windows before that, so that the `msys-2.0.dll` file can be updated). - -3. After you run the `setup-git-sdk.bat` the custom git-for-windows `msys2-runtime` got installed. Now it is time to fire up the *MinGW* shell and update the rest of the system and install the build dependencies. To update the system run `pacman -Su --noconfirm` and to install the dependencies run `pacman -S --noconfirm python less openssh patch make tar diffutils ca-certificates perl-Error perl perl-Authen-SASL perl-libwww perl-MIME-tools perl-Net-SMTP-SSL perl-TermReadKey winpty-git mingw-w64--curl mingw-w64--expat mingw-w64--openssl mingw-w64--tcl mingw-w64--pcre`. \ is "i686" for the 32bit version. +2. Download [setup-git-sdk.bat](https://raw.githubusercontent.com/nalla/build-extra/master/setup-git-sdk.bat) and [setup-git-sdk.sh](https://raw.githubusercontent.com/nalla/build-extra/master/setup-git-sdk.sh) and put them in the the top-level MSys2 directory. Then run the `setup-git-sdk.bat` in a `cmd` window (you need to close all MSys2 windows before that, so that the `msys-2.0.dll` file can be updated). The `setup-git-sdk.bat` updates the `msys2-runtime` and will call the `setup-git-sdk.sh` file that will then install the git build dependencies via `pacman`. # Build Git -1. Clone Git: `cd /usr/src/ && git clone https://github.com/git-for-windows/git`. +1. Open your corresponding *MinGW* Shell + +2. Clone Git: `cd /usr/src/ && git clone https://github.com/git-for-windows/git`. -2. Temporarily: In /usr/src/git/, check out the `update-to-2.3.0` branch: `git remote add -f dscho https://github.com/dscho/git && git checkout -t dscho/update-to-2.3.0`. +3. Temporarily: In /usr/src/git/, check out the `update-to-2.3.0` branch: `git remote add -f dscho https://github.com/dscho/git && git checkout -t dscho/update-to-2.3.0`. -3. Build Git: `make`. +4. Build Git: `make`. -4. Run the test suite: `make test` +5. Run the test suite: `make test` *** From e397a0f235ff3803d929cca75d1bd9a73c00625b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=EB=A7=88=EB=88=84=EC=97=98?= Date: Fri, 27 Feb 2015 09:51:23 +0100 Subject: [PATCH 041/591] Added new page to gather problems and solutions with msys2 --- MSYS2-Notes.md | 3 +++ 1 file changed, 3 insertions(+) create mode 100644 MSYS2-Notes.md diff --git a/MSYS2-Notes.md b/MSYS2-Notes.md new file mode 100644 index 00000000000000..0f2fee75c44788 --- /dev/null +++ b/MSYS2-Notes.md @@ -0,0 +1,3 @@ +Page for things that pop up while fiddling with msys2. + +1. PS1 script: I had to replace `PS1="$PS1"'\n'` with `PS1="$PS1"$'\n'` within the `profile` file to get the git prompt working. See also [this msys2 ticket page](http://sourceforge.net/p/msys2/tickets/17/) \ No newline at end of file From 7596866bf4a4d5df5ebd91a48b6913e9d92308d1 Mon Sep 17 00:00:00 2001 From: dscho Date: Sun, 1 Mar 2015 19:10:08 +0100 Subject: [PATCH 042/591] We need only a single batch file again --- Building-Git.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Building-Git.md b/Building-Git.md index 987075a533de36..78b5dcc18be271 100644 --- a/Building-Git.md +++ b/Building-Git.md @@ -6,7 +6,7 @@ As we are in the process of switching away from msysGit as our development envir 1. Install MSys2 from https://msys2.github.io/, into `C:/msys32` and `C:/msys64` (if you only want to build for one architecture, you can skip the other one). This will install three Shells into the Start Menu: the *MSys*, the *MinGW 32* and the *MinGW 64* Shell. To build Git, you should start the *MinGW* shell corresponding to the architecture of the installed MSys2. -2. Download [setup-git-sdk.bat](https://raw.githubusercontent.com/nalla/build-extra/master/setup-git-sdk.bat) and [setup-git-sdk.sh](https://raw.githubusercontent.com/nalla/build-extra/master/setup-git-sdk.sh) and put them in the the top-level MSys2 directory. Then run the `setup-git-sdk.bat` in a `cmd` window (you need to close all MSys2 windows before that, so that the `msys-2.0.dll` file can be updated). The `setup-git-sdk.bat` updates the `msys2-runtime` and will call the `setup-git-sdk.sh` file that will then install the git build dependencies via `pacman`. +2. Download [setup-git-sdk.bat](https://raw.githubusercontent.com/nalla/build-extra/master/setup-git-sdk.bat) and put them in the the top-level MSys2 directory. Then run the `setup-git-sdk.bat` in a `cmd` window (you need to close all MSys2 windows before that, so that the `msys-2.0.dll` file can be updated). The `setup-git-sdk.bat` updates the `msys2-runtime` and will call the `setup-git-sdk.sh` file that will then install the git build dependencies via `pacman`. # Build Git From 37f3153659a409ac6e5402fb35f5254c3fc835e9 Mon Sep 17 00:00:00 2001 From: dscho Date: Mon, 2 Mar 2015 08:50:13 +0100 Subject: [PATCH 043/591] Remove last remnants of the .sh idea --- Building-Git.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Building-Git.md b/Building-Git.md index 78b5dcc18be271..2e7f8888b97b08 100644 --- a/Building-Git.md +++ b/Building-Git.md @@ -6,7 +6,7 @@ As we are in the process of switching away from msysGit as our development envir 1. Install MSys2 from https://msys2.github.io/, into `C:/msys32` and `C:/msys64` (if you only want to build for one architecture, you can skip the other one). This will install three Shells into the Start Menu: the *MSys*, the *MinGW 32* and the *MinGW 64* Shell. To build Git, you should start the *MinGW* shell corresponding to the architecture of the installed MSys2. -2. Download [setup-git-sdk.bat](https://raw.githubusercontent.com/nalla/build-extra/master/setup-git-sdk.bat) and put them in the the top-level MSys2 directory. Then run the `setup-git-sdk.bat` in a `cmd` window (you need to close all MSys2 windows before that, so that the `msys-2.0.dll` file can be updated). The `setup-git-sdk.bat` updates the `msys2-runtime` and will call the `setup-git-sdk.sh` file that will then install the git build dependencies via `pacman`. +2. Download [setup-git-sdk.bat](https://raw.githubusercontent.com/nalla/build-extra/master/setup-git-sdk.bat) and put it in the the top-level MSys2 directory. Then run the `setup-git-sdk.bat` in a `cmd` window (you need to close all MSys2 windows before that, so that the `msys-2.0.dll` file can be updated). The `setup-git-sdk.bat` updates the `msys2-runtime` and will install the git build dependencies via `pacman`. # Build Git From 0755280d4220a1904828e451041bd674c615a822 Mon Sep 17 00:00:00 2001 From: dscho Date: Tue, 3 Mar 2015 14:27:31 +0100 Subject: [PATCH 044/591] Describe how to print out the incoming environment --- MSYS2-Notes.md | 15 +++++++++++++-- 1 file changed, 13 insertions(+), 2 deletions(-) diff --git a/MSYS2-Notes.md b/MSYS2-Notes.md index 0f2fee75c44788..1cf9161d4a8164 100644 --- a/MSYS2-Notes.md +++ b/MSYS2-Notes.md @@ -1,3 +1,14 @@ -Page for things that pop up while fiddling with msys2. +Page for things that pop up while fiddling with MSys2. -1. PS1 script: I had to replace `PS1="$PS1"'\n'` with `PS1="$PS1"$'\n'` within the `profile` file to get the git prompt working. See also [this msys2 ticket page](http://sourceforge.net/p/msys2/tickets/17/) \ No newline at end of file +1. PS1 script: I had to replace `PS1="$PS1"'\n'` with `PS1="$PS1"$'\n'` within the `profile` file to get the git prompt working. See also [this msys2 ticket page](http://sourceforge.net/p/msys2/tickets/17/) + +2. When trying to debug environment issues, it can be very helpful to print out the environment as it comes into Git. Unfortunately, `mingw_startup()` – which converts the environment to UTF-8 – is run so early that the `sprintf()` family of functions does not work: the locale has not been initialized yet (because this would require the environment, using the `LC_ALL` environment variable!). Therefore, something like this is required: +```c +#include +... +{ + char buffer[1024]; + StringCbPrintf(buffer, sizeof(buffer), "env %d is '%s'\n", i, environ[i]); + write(2, buffer, strlen(buffer)); +} +``` \ No newline at end of file From b5aaeda4784b3e5adece5a840c412c4c95bab221 Mon Sep 17 00:00:00 2001 From: dscho Date: Wed, 4 Mar 2015 09:16:38 +0100 Subject: [PATCH 045/591] Add the incredibly useful tip by @sschuberth about changing the colors in mintty. While at it, convert the enumeration into sections --- MSYS2-Notes.md | 14 +++++++++++--- 1 file changed, 11 insertions(+), 3 deletions(-) diff --git a/MSYS2-Notes.md b/MSYS2-Notes.md index 1cf9161d4a8164..9a4b9745b83224 100644 --- a/MSYS2-Notes.md +++ b/MSYS2-Notes.md @@ -1,8 +1,12 @@ Page for things that pop up while fiddling with MSys2. -1. PS1 script: I had to replace `PS1="$PS1"'\n'` with `PS1="$PS1"$'\n'` within the `profile` file to get the git prompt working. See also [this msys2 ticket page](http://sourceforge.net/p/msys2/tickets/17/) +# PS1 script -2. When trying to debug environment issues, it can be very helpful to print out the environment as it comes into Git. Unfortunately, `mingw_startup()` – which converts the environment to UTF-8 – is run so early that the `sprintf()` family of functions does not work: the locale has not been initialized yet (because this would require the environment, using the `LC_ALL` environment variable!). Therefore, something like this is required: +I had to replace `PS1="$PS1"'\n'` with `PS1="$PS1"$'\n'` within the `profile` file to get the git prompt working. See also [this msys2 ticket page](http://sourceforge.net/p/msys2/tickets/17/) + +# Debugging the environment conversion to UTF-8 + +When trying to debug environment issues, it can be very helpful to print out the environment as it comes into Git. Unfortunately, `mingw_startup()` – which converts the environment to UTF-8 – is run so early that the `sprintf()` family of functions does not work: the locale has not been initialized yet (because this would require the environment, using the `LC_ALL` environment variable!). Therefore, something like this is required: ```c #include ... @@ -11,4 +15,8 @@ Page for things that pop up while fiddling with MSys2. StringCbPrintf(buffer, sizeof(buffer), "env %d is '%s'\n", i, environ[i]); write(2, buffer, strlen(buffer)); } -``` \ No newline at end of file +``` + +# Changing the colors in the Terminal + +See https://github.com/mavnn/mintty-colors-solarized \ No newline at end of file From d30918ed0af27db798c5fc1aff1300d886bdaf76 Mon Sep 17 00:00:00 2001 From: Thomas Braun Date: Fri, 6 Mar 2015 12:16:30 +0100 Subject: [PATCH 046/591] Updated MSYS2 Notes (markdown) --- MSYS2-Notes.md | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) diff --git a/MSYS2-Notes.md b/MSYS2-Notes.md index 9a4b9745b83224..4776472de9f874 100644 --- a/MSYS2-Notes.md +++ b/MSYS2-Notes.md @@ -19,4 +19,15 @@ When trying to debug environment issues, it can be very helpful to print out the # Changing the colors in the Terminal -See https://github.com/mavnn/mintty-colors-solarized \ No newline at end of file +See https://github.com/mavnn/mintty-colors-solarized + +# Building the git documentation +- pacman -S asciidoc xmlto +- start a msys shell +- make doc + +In a mingw32 shell asciidoc fails with +``` +../git/Documentation$ asciidoc git-annotate.txt +asciidoc: FAILED: configuration file asciidoc.conf missing +``` From 12115eeac968cab66cf01d6ea2903e5dcb32025e Mon Sep 17 00:00:00 2001 From: Thomas Braun Date: Fri, 6 Mar 2015 12:26:02 +0100 Subject: [PATCH 047/591] Updated MSYS2 Notes (markdown) --- MSYS2-Notes.md | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/MSYS2-Notes.md b/MSYS2-Notes.md index 4776472de9f874..fedbbdeb9e71c9 100644 --- a/MSYS2-Notes.md +++ b/MSYS2-Notes.md @@ -31,3 +31,7 @@ In a mingw32 shell asciidoc fails with ../git/Documentation$ asciidoc git-annotate.txt asciidoc: FAILED: configuration file asciidoc.conf missing ``` + +# Openssh + +Complains about world writeable private key files, although that makes no sense on windows. From 70cc75b62b3fdb73de92ae864083bf1e6ad53637 Mon Sep 17 00:00:00 2001 From: Thomas Braun Date: Fri, 6 Mar 2015 16:50:40 +0100 Subject: [PATCH 048/591] Updated MSYS2 Notes (markdown) --- MSYS2-Notes.md | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/MSYS2-Notes.md b/MSYS2-Notes.md index fedbbdeb9e71c9..bf7ccfc7d7b25d 100644 --- a/MSYS2-Notes.md +++ b/MSYS2-Notes.md @@ -35,3 +35,8 @@ asciidoc: FAILED: configuration file asciidoc.conf missing # Openssh Complains about world writeable private key files, although that makes no sense on windows. +Can be fixed with + +``` +chmod 600 ~/.ssh/* +``` \ No newline at end of file From aa4f054a0b338015d782ce6fa9d54cfc36ebf903 Mon Sep 17 00:00:00 2001 From: dscho Date: Fri, 6 Mar 2015 18:19:35 +0100 Subject: [PATCH 049/591] Describe the upload process --- Package-management.md | 31 +++++++++++++++++++++++++++---- 1 file changed, 27 insertions(+), 4 deletions(-) diff --git a/Package-management.md b/Package-management.md index d72e6290673ddf..bc979e8496cf6c 100644 --- a/Package-management.md +++ b/Package-management.md @@ -84,12 +84,35 @@ perl -MCPAN -e shell ## Repository structure -TBD +Pacman repositories are served via HTTP, as static files in a single directory. The most important file in that directory is the *package index*, called `.db.tar.xz` by convention. This package index can be updated via `repo-add ...` (this updated *only* the package index, it does *not* copy the package files into the same directory). Pacman expects to find the package files referenced in the package index in the same directory as the index. + +The *Git for Windows*-specific packages are served from Bintray, see [below](#Bintray). +We ship packages for two architectures, [`i686`](https://dl.bintray.com/git-for-windows/pacman/msys2/i686/) and [`x86_64`](https://dl.bintray.com/git-for-windows/pacman/msys2/x86_64/). ## Bintray -TBD +[Bintray](https://bintray.com) hosts repositories of binary files, much like GitHub hosts repositories of source files. Git for Windows' binary files are [hosted on Bintray](https://bintray.com/git-for-windows/). + +Git for Windows' [most important repository hosted on Bintray](https://bintray.com/git-for-windows/pacman) contains the Pacman repositories [described above](#Repository_structure). The section to add to `pacman.conf` to access this repository is: + +```ini +[git-for-windows] +Server = https://dl.bintray.com/$repo/pacman/msys2/$arch^ +SigLevel = Optional +``` + +## How to upload new versions (*Git for Windows* maintainers only) + +To upload new files, a maintainer needs to have permission to write to the `pacman` repository on Bintray. We have a helpful tool in the [`build-extra`](https://github.com/git-for-windows/build-extra) repository to assist in the process, called `pacman-mirror.sh`. After building a new package version (preferably for 32-bit *and* 64-bit), the tool should be used thusly: + +```bash +/path/to/build-extra/pacman-mirror.sh fetch +/path/to/build-extra/pacman-mirror.sh add \ + /path/to/--i686.pkg.tar.xz \ + /path/to/--x86_64.pkg.tar.xz +/path/to/build-extra/pacman-mirror.sh push +``` -## How to upload new versions (Git for Windows core developers only) +The `fetch` step will initialize or synchronize the local mirror of the Pacman repository, the `add` step will copy the packages into the appropriate location, and the `push` step will update the package index, and upload the packages that are not yet on Bintray as well as the package index. -TODO: explain how to use `repo-add` \ No newline at end of file +Note: The `pacman-mirror.sh` tool takes no precaution against simultaneous use. You *will* want to coordinate with your fellow maintainers to avoid running it at the same time as somebody else. \ No newline at end of file From 870fc1a37d735ac91b9bc7c93eb36e2a1b0735bb Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=EB=A7=88=EB=88=84=EC=97=98?= Date: Sat, 7 Mar 2015 13:37:28 +0100 Subject: [PATCH 050/591] Removed temporary stuff. --- Building-Git.md | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/Building-Git.md b/Building-Git.md index 2e7f8888b97b08..c2030e85ed0139 100644 --- a/Building-Git.md +++ b/Building-Git.md @@ -6,7 +6,7 @@ As we are in the process of switching away from msysGit as our development envir 1. Install MSys2 from https://msys2.github.io/, into `C:/msys32` and `C:/msys64` (if you only want to build for one architecture, you can skip the other one). This will install three Shells into the Start Menu: the *MSys*, the *MinGW 32* and the *MinGW 64* Shell. To build Git, you should start the *MinGW* shell corresponding to the architecture of the installed MSys2. -2. Download [setup-git-sdk.bat](https://raw.githubusercontent.com/nalla/build-extra/master/setup-git-sdk.bat) and put it in the the top-level MSys2 directory. Then run the `setup-git-sdk.bat` in a `cmd` window (you need to close all MSys2 windows before that, so that the `msys-2.0.dll` file can be updated). The `setup-git-sdk.bat` updates the `msys2-runtime` and will install the git build dependencies via `pacman`. +2. Download [setup-git-sdk.bat](https://raw.githubusercontent.com/git-for-windows/build-extra/master/setup-git-sdk.bat) and put it in the the top-level MSys2 directory. Then run the `setup-git-sdk.bat` in a `cmd` window (you need to close all MSys2 windows before that, so that the `msys-2.0.dll` file can be updated). The `setup-git-sdk.bat` updates the `msys2-runtime` and will install the git build dependencies via `pacman`. # Build Git @@ -14,8 +14,6 @@ As we are in the process of switching away from msysGit as our development envir 2. Clone Git: `cd /usr/src/ && git clone https://github.com/git-for-windows/git`. -3. Temporarily: In /usr/src/git/, check out the `update-to-2.3.0` branch: `git remote add -f dscho https://github.com/dscho/git && git checkout -t dscho/update-to-2.3.0`. - 4. Build Git: `make`. 5. Run the test suite: `make test` From b5d63004474d1639fa24b10e9fb741935bdcaa59 Mon Sep 17 00:00:00 2001 From: dscho Date: Mon, 9 Mar 2015 15:03:16 +0100 Subject: [PATCH 051/591] Skip no longer necessary step, point out that you need to use MSys to compile --- Building-Git.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/Building-Git.md b/Building-Git.md index c2030e85ed0139..2f416bc588d79f 100644 --- a/Building-Git.md +++ b/Building-Git.md @@ -24,11 +24,11 @@ _Note_: if you encounter messages like `39 [main] make 7628 child_info_fork::abo # Build the `msys2-⁠runtime` -1. Install the MSys2 Toolchain: `pacman -⁠S gcc binutils make`. +1. Start the *MSys* shell (i.e. not the *MinGW 32-bit* nor the *MinGW 64-bit* one). -2. Clone the MSYS2-packages repository: `cd /usr/src && git clone https://github.com/git-for-windows/MSYS2-packages`. +2. Install the MSys2 Toolchain: `pacman -⁠S gcc binutils make`. -3. Temporarily: In MSYS2-packages, check out the `msys-runtime` branch: `git remote add -f dscho https://github.com/dscho/MSYS2-packages && git checkout -t dscho/msys-runtime`. +3. Clone the MSYS2-packages repository: `cd /usr/src && git clone https://github.com/git-for-windows/MSYS2-packages`. 4. Build the package: `makepkg -⁠s`. From cb10af25a6bf4d6ac0bfae6097f46bc7b3bb4b6d Mon Sep 17 00:00:00 2001 From: dscho Date: Mon, 9 Mar 2015 15:27:39 +0100 Subject: [PATCH 052/591] We also host MinGW in addition to MSys2 packages on Bintray --- Package-management.md | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/Package-management.md b/Package-management.md index bc979e8496cf6c..3f763d5b555816 100644 --- a/Package-management.md +++ b/Package-management.md @@ -87,7 +87,7 @@ perl -MCPAN -e shell Pacman repositories are served via HTTP, as static files in a single directory. The most important file in that directory is the *package index*, called `.db.tar.xz` by convention. This package index can be updated via `repo-add ...` (this updated *only* the package index, it does *not* copy the package files into the same directory). Pacman expects to find the package files referenced in the package index in the same directory as the index. The *Git for Windows*-specific packages are served from Bintray, see [below](#Bintray). -We ship packages for two architectures, [`i686`](https://dl.bintray.com/git-for-windows/pacman/msys2/i686/) and [`x86_64`](https://dl.bintray.com/git-for-windows/pacman/msys2/x86_64/). +We ship MSys2 packages for two architectures, [`i686`](https://dl.bintray.com/git-for-windows/pacman/msys2/i686/) and [`x86_64`](https://dl.bintray.com/git-for-windows/pacman/msys2/x86_64/) and also MinGW packages for [`i686`](https://dl.bintray.com/git-for-windows/pacman/mingw/i686/) and [`x86_64`](https://dl.bintray.com/git-for-windows/pacman/mingw/x86_64/). ## Bintray @@ -97,6 +97,7 @@ Git for Windows' [most important repository hosted on Bintray](https://bintray.c ```ini [git-for-windows] +Server = https://dl.bintray.com/$repo/pacman/mingw/$arch^ Server = https://dl.bintray.com/$repo/pacman/msys2/$arch^ SigLevel = Optional ``` From e201e1a9aa604ef517ed88f28afba60d4adf5eab Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=EB=A7=88=EB=88=84=EC=97=98?= Date: Tue, 10 Mar 2015 08:38:44 +0100 Subject: [PATCH 053/591] Fixed typo --- Package-management.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/Package-management.md b/Package-management.md index 3f763d5b555816..99d5569fc1224e 100644 --- a/Package-management.md +++ b/Package-management.md @@ -97,8 +97,8 @@ Git for Windows' [most important repository hosted on Bintray](https://bintray.c ```ini [git-for-windows] -Server = https://dl.bintray.com/$repo/pacman/mingw/$arch^ -Server = https://dl.bintray.com/$repo/pacman/msys2/$arch^ +Server = https://dl.bintray.com/$repo/pacman/mingw/$arch +Server = https://dl.bintray.com/$repo/pacman/msys2/$arch SigLevel = Optional ``` From cee7fe01337e91a79322cc6a194d0925f3b06693 Mon Sep 17 00:00:00 2001 From: nalla Date: Tue, 24 Mar 2015 14:22:27 +0100 Subject: [PATCH 054/591] Updated build instructions to reflect the `net-installer` --- Building-Git.md | 20 +++++++------------- 1 file changed, 7 insertions(+), 13 deletions(-) diff --git a/Building-Git.md b/Building-Git.md index 2f416bc588d79f..b89849357b0b85 100644 --- a/Building-Git.md +++ b/Building-Git.md @@ -1,30 +1,24 @@ -We build Git for Windows using [MSys2](https://msys2.github.io/). - -As we are in the process of switching away from msysGit as our development environment, the following instructions are a little rough on the edges. This situation should become better over the next months. +We build Git for Windows using an [MSys2](https://msys2.github.io/) based *Git for Windows SDK*. This SDK can be installed via a [net-installer](https://github.com/git-for-windows/build-extra/releases) # Installing a build environment -1. Install MSys2 from https://msys2.github.io/, into `C:/msys32` and `C:/msys64` (if you only want to build for one architecture, you can skip the other one). This will install three Shells into the Start Menu: the *MSys*, the *MinGW 32* and the *MinGW 64* Shell. To build Git, you should start the *MinGW* shell corresponding to the architecture of the installed MSys2. - -2. Download [setup-git-sdk.bat](https://raw.githubusercontent.com/git-for-windows/build-extra/master/setup-git-sdk.bat) and put it in the the top-level MSys2 directory. Then run the `setup-git-sdk.bat` in a `cmd` window (you need to close all MSys2 windows before that, so that the `msys-2.0.dll` file can be updated). The `setup-git-sdk.bat` updates the `msys2-runtime` and will install the git build dependencies via `pacman`. +1. Just install the [net-installer](https://github.com/git-for-windows/build-extra/releases). # Build Git -1. Open your corresponding *MinGW* Shell +1. An initial `git clone` and `make` should have already occurred when installing the [net-installer](https://github.com/git-for-windows/build-extra/releases). + +2. Open the *Git for Windows SDK* by double clicking either `mingw32_shell.bat` or `mingw64_shell.bat`. -2. Clone Git: `cd /usr/src/ && git clone https://github.com/git-for-windows/git`. +2. `cd /usr/src/git`. 4. Build Git: `make`. 5. Run the test suite: `make test` -*** - -_Note_: if you encounter messages like `39 [main] make 7628 child_info_fork::abort:...` while running make, follow the following MSYS2 [Issue](http://sourceforge.net/p/msys2/tickets/74/) post, in short: close all MSys2 windows and run the `autorebase.bat` script in the top-level MSys2 directory from a `cmd`. - # Build the `msys2-⁠runtime` -1. Start the *MSys* shell (i.e. not the *MinGW 32-bit* nor the *MinGW 64-bit* one). +1. Start the *MSys* (`msys2_shell.bat`) shell (i.e. not the *MinGW 32-bit* nor the *MinGW 64-bit* one). 2. Install the MSys2 Toolchain: `pacman -⁠S gcc binutils make`. From 134bb6ff79cad9fc914c1db6ba13c1e93bb6e852 Mon Sep 17 00:00:00 2001 From: nalla Date: Tue, 24 Mar 2015 14:38:24 +0100 Subject: [PATCH 055/591] Removed msys2-runtime build instructions. --- Building-Git.md | 14 +------------- 1 file changed, 1 insertion(+), 13 deletions(-) diff --git a/Building-Git.md b/Building-Git.md index b89849357b0b85..390b001b249d88 100644 --- a/Building-Git.md +++ b/Building-Git.md @@ -14,16 +14,4 @@ We build Git for Windows using an [MSys2](https://msys2.github.io/) based *Git f 4. Build Git: `make`. -5. Run the test suite: `make test` - -# Build the `msys2-⁠runtime` - -1. Start the *MSys* (`msys2_shell.bat`) shell (i.e. not the *MinGW 32-bit* nor the *MinGW 64-bit* one). - -2. Install the MSys2 Toolchain: `pacman -⁠S gcc binutils make`. - -3. Clone the MSYS2-packages repository: `cd /usr/src && git clone https://github.com/git-for-windows/MSYS2-packages`. - -4. Build the package: `makepkg -⁠s`. - -(You might need to call `pacman -S ca-certificates` to reinstall that package, it seems that it was not installed properly at least in one MSys2 32-bit setup.) \ No newline at end of file +5. Run the test suite: `make test` \ No newline at end of file From 76bff8167c70e7481ef73ef63f4fa7da12dce0ad Mon Sep 17 00:00:00 2001 From: nalla Date: Tue, 24 Mar 2015 14:42:25 +0100 Subject: [PATCH 056/591] Reflect the upcoming desktop shortcut. --- Building-Git.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/Building-Git.md b/Building-Git.md index 390b001b249d88..338badedc3ecb8 100644 --- a/Building-Git.md +++ b/Building-Git.md @@ -8,10 +8,10 @@ We build Git for Windows using an [MSys2](https://msys2.github.io/) based *Git f 1. An initial `git clone` and `make` should have already occurred when installing the [net-installer](https://github.com/git-for-windows/build-extra/releases). -2. Open the *Git for Windows SDK* by double clicking either `mingw32_shell.bat` or `mingw64_shell.bat`. +2. Open the *Git for Windows SDK* shell by double clicking either the Shortcut on the desktop `Git SDK 32-bit.lnk` or by double clicking `mingw32_shell.bat` in the install folder. That is `Git SDK 64-bit.lnk` and `mingw64_shell.bat` for the `64bit` [net-installer](https://github.com/git-for-windows/build-extra/releases). -2. `cd /usr/src/git`. +2. Change directory to the initial clone: `cd /usr/src/git`. -4. Build Git: `make`. +4. (Optional) build Git: `make`. 5. Run the test suite: `make test` \ No newline at end of file From fbbedcac3f46aaffd59fa910d34d7d544e21aa20 Mon Sep 17 00:00:00 2001 From: nalla Date: Tue, 24 Mar 2015 14:44:37 +0100 Subject: [PATCH 057/591] small fixup --- Building-Git.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Building-Git.md b/Building-Git.md index 338badedc3ecb8..a9b7772b4dc3c4 100644 --- a/Building-Git.md +++ b/Building-Git.md @@ -8,7 +8,7 @@ We build Git for Windows using an [MSys2](https://msys2.github.io/) based *Git f 1. An initial `git clone` and `make` should have already occurred when installing the [net-installer](https://github.com/git-for-windows/build-extra/releases). -2. Open the *Git for Windows SDK* shell by double clicking either the Shortcut on the desktop `Git SDK 32-bit.lnk` or by double clicking `mingw32_shell.bat` in the install folder. That is `Git SDK 64-bit.lnk` and `mingw64_shell.bat` for the `64bit` [net-installer](https://github.com/git-for-windows/build-extra/releases). +2. Open the *Git for Windows SDK* *MinGW* shell by double clicking either the Shortcut on the desktop `Git SDK 32-bit.lnk` or by double clicking `mingw32_shell.bat` in the install folder. That is `Git SDK 64-bit.lnk` and `mingw64_shell.bat` for the `64bit` [net-installer](https://github.com/git-for-windows/build-extra/releases). 2. Change directory to the initial clone: `cd /usr/src/git`. From 7e9a33fbc84e03dbb649e62125dc5c588a74d00e Mon Sep 17 00:00:00 2001 From: nalla Date: Tue, 24 Mar 2015 14:45:59 +0100 Subject: [PATCH 058/591] Initial build instructions to build the msys2-runtime --- Building-msys2-runtime.md | 13 +++++++++++++ 1 file changed, 13 insertions(+) create mode 100644 Building-msys2-runtime.md diff --git a/Building-msys2-runtime.md b/Building-msys2-runtime.md new file mode 100644 index 00000000000000..9e01acdade2867 --- /dev/null +++ b/Building-msys2-runtime.md @@ -0,0 +1,13 @@ +# Installing a build environment + +1. Just install the [net-installer](https://github.com/git-for-windows/build-extra/releases). + +# Build `msys2-⁠runtime` + +1. Open the *Git for Windows SDK* *MSys* shell by double clicking `msys2_shell.bat` in the install folder. (i.e. not the *MinGW 32-bit* nor the *MinGW 64-bit* one). + +2. Install the MSys2 Toolchain: `pacman -⁠S gcc binutils make`. + +3. Clone the MSYS2-packages repository: `cd /usr/src && git clone https://github.com/git-for-windows/MSYS2-packages`. + +4. Build the package: `makepkg -⁠s`. \ No newline at end of file From d6c389fb7129eb4758fdf51aa105cdb3450296f3 Mon Sep 17 00:00:00 2001 From: nalla Date: Tue, 24 Mar 2015 14:47:38 +0100 Subject: [PATCH 059/591] Updated link to the new SDK installer. --- FAQ.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/FAQ.md b/FAQ.md index fb65b6cc83a33e..86f0b29e423d08 100644 --- a/FAQ.md +++ b/FAQ.md @@ -1,3 +1,3 @@ ## What is the relationship between *Git for Windows* and *msysGit*? -*Git for Windows* used to be developed using the development environment called "msysGit", but roughly coinciding with Git 2.1, msysGit was superseded by a new development environment: the [Git for Windows SDK](https://github.com/git-for-windows/sdk). +*Git for Windows* used to be developed using the development environment called "msysGit", but roughly coinciding with Git 2.1, msysGit was superseded by a new development environment: the [Git for Windows SDK](https://github.com/git-for-windows/build-extra/releases). From 7e876c2edb1bab0743fa9a5e79b60f414cbc4182 Mon Sep 17 00:00:00 2001 From: nalla Date: Tue, 24 Mar 2015 14:52:27 +0100 Subject: [PATCH 060/591] Add step to change directory. --- Building-msys2-runtime.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/Building-msys2-runtime.md b/Building-msys2-runtime.md index 9e01acdade2867..e2912743b0fd93 100644 --- a/Building-msys2-runtime.md +++ b/Building-msys2-runtime.md @@ -10,4 +10,6 @@ 3. Clone the MSYS2-packages repository: `cd /usr/src && git clone https://github.com/git-for-windows/MSYS2-packages`. +4. Change to the `msys2-runtime` directory: `cd MSYS2-packages/msys2-runtime` + 4. Build the package: `makepkg -⁠s`. \ No newline at end of file From 0fbf8ecb15c66f893a363f8641d9184370c1f892 Mon Sep 17 00:00:00 2001 From: dscho Date: Sun, 29 Mar 2015 16:20:39 +0000 Subject: [PATCH 061/591] Use the home page's SDK link consistently. --- Building-Git.md | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/Building-Git.md b/Building-Git.md index a9b7772b4dc3c4..c3e2603095eacb 100644 --- a/Building-Git.md +++ b/Building-Git.md @@ -1,14 +1,14 @@ -We build Git for Windows using an [MSys2](https://msys2.github.io/) based *Git for Windows SDK*. This SDK can be installed via a [net-installer](https://github.com/git-for-windows/build-extra/releases) +We build Git for Windows using an [MSys2](https://msys2.github.io/) based *Git for Windows SDK*. This SDK can be installed via a [net-installer](https://git-for-windows.github.io/#download-sdk) # Installing a build environment -1. Just install the [net-installer](https://github.com/git-for-windows/build-extra/releases). +1. Just install the [net-installer](https://git-for-windows.github.io/#download-sdk). # Build Git -1. An initial `git clone` and `make` should have already occurred when installing the [net-installer](https://github.com/git-for-windows/build-extra/releases). +1. An initial `git clone` and `make` should have already occurred when installing the [net-installer](https://git-for-windows.github.io/#download-sdk). -2. Open the *Git for Windows SDK* *MinGW* shell by double clicking either the Shortcut on the desktop `Git SDK 32-bit.lnk` or by double clicking `mingw32_shell.bat` in the install folder. That is `Git SDK 64-bit.lnk` and `mingw64_shell.bat` for the `64bit` [net-installer](https://github.com/git-for-windows/build-extra/releases). +2. Open the *Git for Windows SDK* *MinGW* shell by double clicking either the Shortcut on the desktop `Git SDK 32-bit.lnk` or by double clicking `mingw32_shell.bat` in the install folder. That is `Git SDK 64-bit.lnk` and `mingw64_shell.bat` for the `64bit` [net-installer](https://git-for-windows.github.io/#download-sdk). 2. Change directory to the initial clone: `cd /usr/src/git`. From 08203b026c18ed1453a7cef5538162cb09ae0b71 Mon Sep 17 00:00:00 2001 From: dscho Date: Sun, 29 Mar 2015 16:21:49 +0000 Subject: [PATCH 062/591] Use the home page's SDK link consistently. --- Building-msys2-runtime.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Building-msys2-runtime.md b/Building-msys2-runtime.md index e2912743b0fd93..80b03c7aa96213 100644 --- a/Building-msys2-runtime.md +++ b/Building-msys2-runtime.md @@ -1,6 +1,6 @@ # Installing a build environment -1. Just install the [net-installer](https://github.com/git-for-windows/build-extra/releases). +1. Just install the [net-installer](https://git-for-windows.github.io/#download-sdk). # Build `msys2-⁠runtime` From 52cf57406beaabad4fdcf20e77aafaef89ce7faf Mon Sep 17 00:00:00 2001 From: dscho Date: Sun, 29 Mar 2015 16:22:51 +0000 Subject: [PATCH 063/591] It was pointed out by the MSys2 maintainer that the best way to start compiling MSys2 packages is to install `base-devel` --- Building-msys2-runtime.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Building-msys2-runtime.md b/Building-msys2-runtime.md index 80b03c7aa96213..cd17e5c7eff5ab 100644 --- a/Building-msys2-runtime.md +++ b/Building-msys2-runtime.md @@ -6,7 +6,7 @@ 1. Open the *Git for Windows SDK* *MSys* shell by double clicking `msys2_shell.bat` in the install folder. (i.e. not the *MinGW 32-bit* nor the *MinGW 64-bit* one). -2. Install the MSys2 Toolchain: `pacman -⁠S gcc binutils make`. +2. Install the MSys2 Toolchain: `pacman -⁠S base-devel`. 3. Clone the MSYS2-packages repository: `cd /usr/src && git clone https://github.com/git-for-windows/MSYS2-packages`. From de51772e9e8ef0b12ef04ab9285fb226907d289f Mon Sep 17 00:00:00 2001 From: dscho Date: Sun, 29 Mar 2015 16:24:43 +0000 Subject: [PATCH 064/591] The net installer already installs an empty `MSYS2-packages` repository; it just has to be initialized. --- Building-msys2-runtime.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/Building-msys2-runtime.md b/Building-msys2-runtime.md index cd17e5c7eff5ab..e0531a22800736 100644 --- a/Building-msys2-runtime.md +++ b/Building-msys2-runtime.md @@ -8,8 +8,8 @@ 2. Install the MSys2 Toolchain: `pacman -⁠S base-devel`. -3. Clone the MSYS2-packages repository: `cd /usr/src && git clone https://github.com/git-for-windows/MSYS2-packages`. +3. Initialize the local MSYS2-packages clone: `cd /usr/src/MSYS2-packages && git fetch origin && git checkout master`. -4. Change to the `msys2-runtime` directory: `cd MSYS2-packages/msys2-runtime` +4. Change to the `msys2-runtime` directory: `cd msys2-runtime` 4. Build the package: `makepkg -⁠s`. \ No newline at end of file From 504083dd1e3a4cab248cd87e968e083f25614a36 Mon Sep 17 00:00:00 2001 From: dscho Date: Sun, 29 Mar 2015 16:25:58 +0000 Subject: [PATCH 065/591] Updated Building msys2 runtime (markdown) From 190aee51675843eebaab15b873e51778a5b6a2b4 Mon Sep 17 00:00:00 2001 From: dscho Date: Sun, 29 Mar 2015 16:30:22 +0000 Subject: [PATCH 066/591] We unified the Pacman repositories and now have only two left, one for i686 and one for x86_64. --- Package-management.md | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/Package-management.md b/Package-management.md index 99d5569fc1224e..011448d7829795 100644 --- a/Package-management.md +++ b/Package-management.md @@ -87,7 +87,7 @@ perl -MCPAN -e shell Pacman repositories are served via HTTP, as static files in a single directory. The most important file in that directory is the *package index*, called `.db.tar.xz` by convention. This package index can be updated via `repo-add ...` (this updated *only* the package index, it does *not* copy the package files into the same directory). Pacman expects to find the package files referenced in the package index in the same directory as the index. The *Git for Windows*-specific packages are served from Bintray, see [below](#Bintray). -We ship MSys2 packages for two architectures, [`i686`](https://dl.bintray.com/git-for-windows/pacman/msys2/i686/) and [`x86_64`](https://dl.bintray.com/git-for-windows/pacman/msys2/x86_64/) and also MinGW packages for [`i686`](https://dl.bintray.com/git-for-windows/pacman/mingw/i686/) and [`x86_64`](https://dl.bintray.com/git-for-windows/pacman/mingw/x86_64/). +We ship MSys2 and MinGW packages for two architectures, [`i686`](https://dl.bintray.com/git-for-windows/pacman/i686/) and [`x86_64`](https://dl.bintray.com/git-for-windows/pacman/x86_64/). ## Bintray @@ -97,8 +97,7 @@ Git for Windows' [most important repository hosted on Bintray](https://bintray.c ```ini [git-for-windows] -Server = https://dl.bintray.com/$repo/pacman/mingw/$arch -Server = https://dl.bintray.com/$repo/pacman/msys2/$arch +Server = https://dl.bintray.com/$repo/pacman/$arch SigLevel = Optional ``` From c7a1c8547070f9e4850273ba46f2e35f9ef9c343 Mon Sep 17 00:00:00 2001 From: dscho Date: Sun, 29 Mar 2015 16:31:42 +0000 Subject: [PATCH 067/591] `MINGW_INSTALLS` no longer needs to be set; Upstream fixed their `Pacman`. --- Package-management.md | 2 -- 1 file changed, 2 deletions(-) diff --git a/Package-management.md b/Package-management.md index 011448d7829795..027c5adc23ea49 100644 --- a/Package-management.md +++ b/Package-management.md @@ -52,8 +52,6 @@ makepkg-mingw -s (The `-s` flag tells `makepkg` that it should install dependencies automatically as needed) -Note: To compile 32-bit packages, you might need to set `MINGW_INSTALLS=mingw32` first. - To build MSys packages, you need to start the `MSys` shell (which sets `MSYSTEM=MSYS` before running the Bash), clone the [`MSYS2-packages`](https://github.com/git-for-windows/MSYS2-packages) repository (recommended location: `/usr/src/MSYS2-packages`), `cd` to the appropriate subdirectory and call ```bash From 2f2ff70e2dcc99ff6e9ff0043bf9df65e5568b64 Mon Sep 17 00:00:00 2001 From: dscho Date: Sun, 29 Mar 2015 16:44:30 +0000 Subject: [PATCH 068/591] Move the "rebuilding msys2-runtime" instructions from the "Package management" page, where they did not belong in the first place. --- Building-msys2-runtime.md | 14 +++++++++++++- 1 file changed, 13 insertions(+), 1 deletion(-) diff --git a/Building-msys2-runtime.md b/Building-msys2-runtime.md index e0531a22800736..44dd9dcc240a3a 100644 --- a/Building-msys2-runtime.md +++ b/Building-msys2-runtime.md @@ -12,4 +12,16 @@ 4. Change to the `msys2-runtime` directory: `cd msys2-runtime` -4. Build the package: `makepkg -⁠s`. \ No newline at end of file +5. Build the package: `makepkg -⁠s`. + +# Rebuild the msys2-runtime + +When there are bugs in the msys2-runtime (e.g. problems with the POSIX-to-Windows path mangling), you need to rebuild the `msys-2.0.dll`, possibly frequently. + +To rebuild the `msys-2.0.dll` -- assuming that you have built it already as described above -- you first need to start an *MSys* shell by double-clicking the `msys2_shell.bat` script in your Git SDK's top-level directory. Then call `cd /usr/src/MSYs2-packagess/msys2-runtime/src/msys2-runtime/winsup/cygwin`. Now you can modify the source code to your heart's extent. It is actually a local clone of https://github.com/git-for-windows/msys2-runtime; you probably want to add your own fork as a remote. + +To actually build the `msys-2.0.dll`, switch to `src/build--pc-msys/-pc-msys/winsup/cygwin` and type `make`. This will generate an `msys0.dll` file in that directory. This is the new `msys-2.0.dll`, but you cannot simply copy it into `/usr/bin/` because it is in use by the current `mintty` as well as by the current Bash. To update, you need to close all programs using the msys2-runtime (including all of the terminal windows), then copy the `msys0.dll` file, replacing the existing `/usr/bin/msys-2.0.dll`, either using Explorer, `cmd.exe` or a separate Git SDK (for example, when debugging the 64-bit msys2-runtime, a 32-bit Git SDK comes in real handy). You will **want** to make a backup copy of the old `msys-2.0.dll`... + +# Related: building/rebuilding Bash + +The process to rebuild the `Bash` is very similar to the `msys2-runtime` one; You will just need to work in the `src/bash-/` subdirectory of `/usr/src/MSYS2-packages/bash/` (both the sources and the generated `bash.exe` live there). Bash also requires all Bash instances to be exited before the executable is replaced by the new one. And like with the msys2-runtime, you will **want** to make a backup copy of the old `bash.exe`. \ No newline at end of file From f540e96457c1c56418c25e2687fea92485eb07dc Mon Sep 17 00:00:00 2001 From: dscho Date: Sun, 29 Mar 2015 16:45:07 +0000 Subject: [PATCH 069/591] Move instructions for rebuilding the msys2-runtime to the "Building msys2-runtime" page. --- Package-management.md | 8 -------- 1 file changed, 8 deletions(-) diff --git a/Package-management.md b/Package-management.md index 027c5adc23ea49..df950a610c7ab9 100644 --- a/Package-management.md +++ b/Package-management.md @@ -58,14 +58,6 @@ To build MSys packages, you need to start the `MSys` shell (which sets `MSYSTEM= makepkg -s ``` -To rebuild the `msys2-runtime` (i.e. `msys-2.0.dll`), you will need to have a *second* MSys2 installation and quit all applications from the first MSys2 installation. In the second installation, as above, start the `MSys` shell and clone `MSYS2-packages` to `/usr/src/`. - -Inside the `msys2-runtime` subdirectory, you need to use `makepkg -s` *for the initial build*. - -For subsequent builds, after modifying the source files in `src/msys2-runtime/winsup/cygwin/` you can switch to `src/build--pc-msys/-pc-msys/winsup/cygwin` and type `make`. This will generate an `msys0.dll` file in the latter directory that you can then copy to the first MSys2 installation to test. - -The process to rebuild the `Bash` is very similar to the `msys2-runtime` one; You will just need to work in the `src/bash-/` subdirectory of `/usr/src/MSYS2-packages/bash/` (both the sources and the generated `bash.exe` live there). - ## Perl package management Perl packages are managed outside of the `pacman` realm, but instead with [CPAN](http://www.cpan.org/): From fe9ab08cc965ec8414a9b9f40a0211321c7dab4f Mon Sep 17 00:00:00 2001 From: dscho Date: Sun, 29 Mar 2015 16:46:44 +0000 Subject: [PATCH 070/591] Use the default location of the local `build-extra` clone: `/usr/src/` --- Package-management.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/Package-management.md b/Package-management.md index df950a610c7ab9..69629f1097baae 100644 --- a/Package-management.md +++ b/Package-management.md @@ -96,11 +96,11 @@ SigLevel = Optional To upload new files, a maintainer needs to have permission to write to the `pacman` repository on Bintray. We have a helpful tool in the [`build-extra`](https://github.com/git-for-windows/build-extra) repository to assist in the process, called `pacman-mirror.sh`. After building a new package version (preferably for 32-bit *and* 64-bit), the tool should be used thusly: ```bash -/path/to/build-extra/pacman-mirror.sh fetch -/path/to/build-extra/pacman-mirror.sh add \ +/usr/src/build-extra/pacman-mirror.sh fetch +/usr/src/build-extra/pacman-mirror.sh add \ /path/to/--i686.pkg.tar.xz \ /path/to/--x86_64.pkg.tar.xz -/path/to/build-extra/pacman-mirror.sh push +/usr/src/build-extra/pacman-mirror.sh push ``` The `fetch` step will initialize or synchronize the local mirror of the Pacman repository, the `add` step will copy the packages into the appropriate location, and the `push` step will update the package index, and upload the packages that are not yet on Bintray as well as the package index. From 169c87281004027155a548e93786efc0217a9a0e Mon Sep 17 00:00:00 2001 From: dscho Date: Sun, 29 Mar 2015 16:54:14 +0000 Subject: [PATCH 071/591] Explain which repositories contain information to rebuild packages --- Package-management.md | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/Package-management.md b/Package-management.md index 69629f1097baae..d834eabc846a0f 100644 --- a/Package-management.md +++ b/Package-management.md @@ -44,6 +44,12 @@ pacman -Ql ## Rebuild packages +If you want to rebuild a package, the first order of business is to know which repository has the metadata for the package. Git for Windows has three repositories containing such metadata: + +- [build-extra](https://github.com/git-for-windows/build-extra) contains the `git-extra` package information, +- [MINGW-packages](https://github.com/git-for-windows/MINGW-packages) contains the information for the MinGW packages, i.e. packages that do not require any POSIX emulation; by convention, their package name have the `mingw-w64-` prefix, and +- [MSYS2-packages](https://github.com/git-for-windows/MSYS2-packages) contains the information for all packages that require a POSIX emulation, such as Bash, OpenSSH, etc. The `MSYS2-packages` repository also contains the information of the package *providing* the POSIX emulation: [`msys2-runtime`](https://github.com/git-for-windows/msys2-runtime) (see also [Building msys2-runtime](Building-msys2-runtime)). + To build MinGW packages, you need to start the appropriate `MinGW` shell (32-bit or 64-bit – this sets `MSYSTEM=MINGW32` or `MSYSTEM=MINGW64` respectively), clone the [`MINGW-packages`](https://github.com/git-for-windows/MINGW-packages) repository (recommended location: `/usr/src/MINGW-packages`), `cd` to the appropriate subdirectory and call ```bash From 2a70fa7e404a3f807cc18cb0698f32a3782788f6 Mon Sep 17 00:00:00 2001 From: dscho Date: Sun, 29 Mar 2015 16:58:31 +0000 Subject: [PATCH 072/591] Mention the PKGBUILD files --- Package-management.md | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/Package-management.md b/Package-management.md index d834eabc846a0f..16b87d52055d09 100644 --- a/Package-management.md +++ b/Package-management.md @@ -64,6 +64,10 @@ To build MSys packages, you need to start the `MSys` shell (which sets `MSYSTEM= makepkg -s ``` +### More details about rebuilding packages + +The `makepkg` script is part of the `pacman` package itself. It expects a [`PKGBUILD`](https://wiki.archlinux.org/index.php/PKGBUILD) file in the current directory that contains metadata about the package and functions specifying how to prepare the source code, build the executables, and package all the files. + ## Perl package management Perl packages are managed outside of the `pacman` realm, but instead with [CPAN](http://www.cpan.org/): From e07026d8db5d8a5928d2dc432a8248d60411af01 Mon Sep 17 00:00:00 2001 From: nalla Date: Mon, 30 Mar 2015 14:07:38 +0200 Subject: [PATCH 073/591] Added `prove` invocation --- Building-Git.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Building-Git.md b/Building-Git.md index c3e2603095eacb..bbc25b74882198 100644 --- a/Building-Git.md +++ b/Building-Git.md @@ -14,4 +14,4 @@ We build Git for Windows using an [MSys2](https://msys2.github.io/) based *Git f 4. (Optional) build Git: `make`. -5. Run the test suite: `make test` \ No newline at end of file +5. Run the test suite: `make test`. If you are a fan of statistics, you can use the following `prove` invocation to run the testsuite. But first we have to change to the test directory with the command `cd t`. After that you can issue `/usr/bin/time prove -j 15 --state=failed,save ./t[0-9]*.sh`. If *15* threads are too many for your system, you can provide the number of threads via the `-j ` (j for jobs) parameter. \ No newline at end of file From 67505c3e11bd2942ab06f9e036be753e781ba65f Mon Sep 17 00:00:00 2001 From: nalla Date: Mon, 30 Mar 2015 14:49:29 +0200 Subject: [PATCH 074/591] Initial release of wiki page --- Rebasing-Git-for-Windows.md | 40 +++++++++++++++++++++++++++++++++++++ 1 file changed, 40 insertions(+) create mode 100644 Rebasing-Git-for-Windows.md diff --git a/Rebasing-Git-for-Windows.md b/Rebasing-Git-for-Windows.md new file mode 100644 index 00000000000000..877269465ffd7e --- /dev/null +++ b/Rebasing-Git-for-Windows.md @@ -0,0 +1,40 @@ +To do a *rebase* of the *Git for Windows* source onto a new [upstream](https://github.com/git/git) *Git* release, follow this guideline. + +# Assumptions +1. You want to *rebase* onto a new [upstream](https://github.com/git/git) release tagged as `v2.3.4` +2. The latest *rebase* was done onto a [upstream](https://github.com/git/git) release tagged as `v2.3.3` + +# Preconditions +1. A working [Git for Windows SDK](https://git-for-windows.github.io/#download-sdk). +2. A fetched build-extra repository. + `cd /usr/src/build-extra` + `git fetch` + `git checkout master` +3. Working directory set to current *Git for Windows* source. + `cd /usr/src/git` +4. Added [upstream](https://github.com/git/git) as a remote. + `git remote add git https://github.com/git/git` + `git fetch git` + +# Starting the *rebase* +1. Find the commit of the last *rebase* and remember it. + `BASE="$(git rev-parse ":/Start the merging-rebase")"` +2. Run the `shears.sh` script to build up the actual *rebase* script. + `../build-extra/./shears.sh --merging --onto v2.3.4 $BASE` + Note: `v2.3.4` is a `tag` in the remote `git`. +3. The *rebase* should start automatically and occasionally stop if it hits any merge conflicts. Resolve those conflicts and then continue the rebase. + `git rebase --continue` + +# Verifying the *rebase* +1. Generate a *diff* of the previous state. + `git diff v2.3.3..origin/master > prev.diff` +2. Generate a *diff* of the current state. + `git diff v2.3.4..master > curr.diff` +3. *Diff* the *diffs*. + `git diff --no-index prev.diff curr.diff` + + >Ideally, the resulting output will show changes only in the `@@` lines of `prev.diff` vs `curr.diff`. + >It's a bit hard to read, though, because it is a diff of a diff. + >So meta. + >When there is a line that starts with a `-` or a `+` but then continues with a space, that's good! + >It means that the context of our changes changed. \ No newline at end of file From 49f4e3003d765e4654fe4c0f1cf952522955263b Mon Sep 17 00:00:00 2001 From: dscho Date: Fri, 3 Apr 2015 20:32:49 +0000 Subject: [PATCH 075/591] Mention (and link to a description of) minimal, complete, verifiable examples --- Issue-reporting-guidelines.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Issue-reporting-guidelines.md b/Issue-reporting-guidelines.md index b17d35107b0fc7..cd930e8731e525 100644 --- a/Issue-reporting-guidelines.md +++ b/Issue-reporting-guidelines.md @@ -1,7 +1,7 @@ * Search the existing [open](https://github.com/git-for-windows/git/issues?q=is%3Aopen) and [closed](https://github.com/git-for-windows/git/issues?q=is%3Aclosed) issues. Maybe the bug was already reported? * Include the output of git --version and the Windows version. In case the issue might depend on the server include its git version and OS version also. * Describe your issue properly. If you spend 30 seconds throwing out a sloppy report, do expect that others will spend exactly the same amount on trying to resolve it. -* Include a minimal working example using the codeblock delimiters from Github Markdown. +* Include a [Minimal, Complete, and Verifiable example](http://stackoverflow.com/help/mcve) using GitHub Markdown's `codeblock` delimiters. * If your issue stems from a particular repository include its URL. If the repository is proprietary try to create a public test repository showing the same issue. * Be prepared to test fixes! * Be polite. You are asking highly competent software developers for help, for free, so you might want to avoid treating them as if they were a commodity or at your free disposal. From 7caecf5c83ba4cba72af0d10f25ac6190723b929 Mon Sep 17 00:00:00 2001 From: dscho Date: Mon, 6 Apr 2015 15:41:41 +0200 Subject: [PATCH 076/591] Give people an idea where to start when they want to contribute --- Making-an-installer.md | 10 ++++++++++ 1 file changed, 10 insertions(+) create mode 100644 Making-an-installer.md diff --git a/Making-an-installer.md b/Making-an-installer.md new file mode 100644 index 00000000000000..3dd4e0b2a1e824 --- /dev/null +++ b/Making-an-installer.md @@ -0,0 +1,10 @@ +To make an installer, install the [SDK](https://git-for-windows.github.io/#download-sdk), run it and then issue the following commands: + +```bash +cd /usr/src/build-extra +git fetch +git checkout master +./installer/release.sh -test +``` + +where `` is the Git version. \ No newline at end of file From 3b06b601cf253f6360214fd7f1a1249f018d80b9 Mon Sep 17 00:00:00 2001 From: dscho Date: Mon, 6 Apr 2015 15:42:18 +0200 Subject: [PATCH 077/591] Give people an idea where to start when they want to contribute --- Making-a-portable-Git.md | 10 ++++++++++ 1 file changed, 10 insertions(+) create mode 100644 Making-a-portable-Git.md diff --git a/Making-a-portable-Git.md b/Making-a-portable-Git.md new file mode 100644 index 00000000000000..bdc63a93bca317 --- /dev/null +++ b/Making-a-portable-Git.md @@ -0,0 +1,10 @@ +To make an installer, install the [SDK](https://git-for-windows.github.io/#download-sdk), run it and then issue the following commands: + +```bash +cd /usr/src/build-extra +git fetch +git checkout master +./portable/release.sh -test +``` + +where `` is the Git version. \ No newline at end of file From 4f34e6aa0d27ba9ab38766400a67d0a372822b8a Mon Sep 17 00:00:00 2001 From: Yonggang Luo Date: Tue, 7 Apr 2015 01:48:07 +0800 Subject: [PATCH 078/591] Updated Building Git (markdown) --- Building-Git.md | 22 +++++++++++++++++++++- 1 file changed, 21 insertions(+), 1 deletion(-) diff --git a/Building-Git.md b/Building-Git.md index bbc25b74882198..9489b6d77c976b 100644 --- a/Building-Git.md +++ b/Building-Git.md @@ -14,4 +14,24 @@ We build Git for Windows using an [MSys2](https://msys2.github.io/) based *Git f 4. (Optional) build Git: `make`. -5. Run the test suite: `make test`. If you are a fan of statistics, you can use the following `prove` invocation to run the testsuite. But first we have to change to the test directory with the command `cd t`. After that you can issue `/usr/bin/time prove -j 15 --state=failed,save ./t[0-9]*.sh`. If *15* threads are too many for your system, you can provide the number of threads via the `-j ` (j for jobs) parameter. \ No newline at end of file +5. Run the test suite: `make test`. If you are a fan of statistics, you can use the following `prove` invocation to run the testsuite. But first we have to change to the test directory with the command `cd t`. After that you can issue `/usr/bin/time prove -j 15 --state=failed,save ./t[0-9]*.sh`. If *15* threads are too many for your system, you can provide the number of threads via the `-j ` (j for jobs) parameter. + +6. Command Lines for building git and git documents +``` +cd /usr/src +git clone https://github.com/git-for-windows/git.git +cd git +# verify that the test suite passes +make -j5 all +cd t +/usr/bin/time prove -j 5 --state=failed,save ./t[0-9]*.sh + +# install the git binaries +make install + +# make & install the html documentation +cd /usr/src/git/Documentation +make html +DIFF='diff' HOME='/mingw64' make install-html #/mingw32 if for 32bit arch + +``` \ No newline at end of file From f761932ff1ace4ec43cf902b472f1ff756f6ebbf Mon Sep 17 00:00:00 2001 From: dscho Date: Mon, 6 Apr 2015 22:26:28 +0200 Subject: [PATCH 079/591] Fix: the building part was already described very well. Probably the intention of the latest edits was to help updating to the newest Git version. --- Building-Git.md | 25 +++++++++++-------------- 1 file changed, 11 insertions(+), 14 deletions(-) diff --git a/Building-Git.md b/Building-Git.md index 9489b6d77c976b..7879d5921df1cc 100644 --- a/Building-Git.md +++ b/Building-Git.md @@ -16,22 +16,19 @@ We build Git for Windows using an [MSys2](https://msys2.github.io/) based *Git f 5. Run the test suite: `make test`. If you are a fan of statistics, you can use the following `prove` invocation to run the testsuite. But first we have to change to the test directory with the command `cd t`. After that you can issue `/usr/bin/time prove -j 15 --state=failed,save ./t[0-9]*.sh`. If *15* threads are too many for your system, you can provide the number of threads via the `-j ` (j for jobs) parameter. -6. Command Lines for building git and git documents +# Updating to the newest Git for Windows version + +```bash +cd /usr/src/git +git pull +make -j15 install install-html ``` -cd /usr/src -git clone https://github.com/git-for-windows/git.git -cd git -# verify that the test suite passes -make -j5 all -cd t -/usr/bin/time prove -j 5 --state=failed,save ./t[0-9]*.sh -# install the git binaries -make install +## Testing the new Git version -# make & install the html documentation -cd /usr/src/git/Documentation -make html -DIFF='diff' HOME='/mingw64' make install-html #/mingw32 if for 32bit arch +As before: +```bash +cd /usr/src/git/t +/usr/bin/time prove -j 5 --state=failed,save ./t[0-9]*.sh ``` \ No newline at end of file From 073f8d9d9469cf7191a5f81210ae1059e3616ae4 Mon Sep 17 00:00:00 2001 From: dscho Date: Tue, 7 Apr 2015 10:47:06 +0200 Subject: [PATCH 080/591] Mention how to upgrade all packages, add a caveat about the "tricky to update" packages --- Package-management.md | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/Package-management.md b/Package-management.md index 16b87d52055d09..b343f44b08478f 100644 --- a/Package-management.md +++ b/Package-management.md @@ -20,6 +20,18 @@ To ensure that the newest package version is installed, it is recommended to pas pacman -Sy ``` +To upgrade all packages to their newest versions, call + +```bash +pacman -Syu +``` + +### Updating `msys2-runtime`, `pacman` and `bash` + +As `pacman.exe` is itself an MSys2 executable, it is strongly suggested to update `msys2-runtime` and `pacman` packages individually if they need to be updated, and let `pacman` quit *immediately* afterwards. + +Likewise, if you run `pacman` from a `bash` -- an MSys2 program, too -- you should quit the shell *immediately* (it might show an infinite stream of heap messages instead of quitting, requiring to be force-quit). + ## Remove packages ```bash From 4511d87a84f4aea4bfbcbdd68ad427a3ba330429 Mon Sep 17 00:00:00 2001 From: dscho Date: Tue, 7 Apr 2015 10:48:50 +0200 Subject: [PATCH 081/591] Mention the need to update the Git SDK before making the installer --- Making-an-installer.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/Making-an-installer.md b/Making-an-installer.md index 3dd4e0b2a1e824..c689ee903335d4 100644 --- a/Making-an-installer.md +++ b/Making-an-installer.md @@ -1,3 +1,5 @@ +As the installer is made by putting together files from the Git SDK, it is advisable to update those files first. To update the packages, call `pacman -Syu` ([caveats apply](https://github.com/git-for-windows/git/wiki/Package-management#updating-msys2-runtime-pacman-and-bash)). If you want to test Git changes or make an installer from your own Git fork, you need to call `cd /usr/src/git && make install` (for documentation changes, `make install-html`). + To make an installer, install the [SDK](https://git-for-windows.github.io/#download-sdk), run it and then issue the following commands: ```bash From 2ade887ddb019e0666ee8d1019fffe4d7d3b7dc5 Mon Sep 17 00:00:00 2001 From: dscho Date: Tue, 7 Apr 2015 10:50:44 +0200 Subject: [PATCH 082/591] Mention how to upgrade all packages, add a caveat about the "tricky to update" packages --- Making-a-portable-Git.md | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/Making-a-portable-Git.md b/Making-a-portable-Git.md index bdc63a93bca317..a8901b45a32704 100644 --- a/Making-a-portable-Git.md +++ b/Making-a-portable-Git.md @@ -1,4 +1,6 @@ -To make an installer, install the [SDK](https://git-for-windows.github.io/#download-sdk), run it and then issue the following commands: +As the portable Git is made by putting together files from the Git SDK, it is advisable to update those files first. To update the packages, call `pacman -Syu` ([caveats apply](https://github.com/git-for-windows/git/wiki/Package-management#updating-msys2-runtime-pacman-and-bash)). If you want to test Git changes or make an portable Git from your own Git fork, you need to call `cd /usr/src/git && make install` (for documentation changes, `make install-html`). + +To package the portable Git, install the [SDK](https://git-for-windows.github.io/#download-sdk), run it and then issue the following commands: ```bash cd /usr/src/build-extra From be2f60cff3b1f1ad4a0cd15d4b29bc1c936f0895 Mon Sep 17 00:00:00 2001 From: dscho Date: Mon, 13 Apr 2015 10:15:15 +0200 Subject: [PATCH 083/591] Link to Simon Tatham's *extensive* bug reporting guidelines --- Issue-reporting-guidelines.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Issue-reporting-guidelines.md b/Issue-reporting-guidelines.md index cd930e8731e525..5b4d5d823fafb3 100644 --- a/Issue-reporting-guidelines.md +++ b/Issue-reporting-guidelines.md @@ -6,4 +6,4 @@ * Be prepared to test fixes! * Be polite. You are asking highly competent software developers for help, for free, so you might want to avoid treating them as if they were a commodity or at your free disposal. * An example for an outstanding report can be found [here](https://github.com/msysgit/msysgit/issues/206#issuecomment-44574988). You may want to imitate the level of detail. -* For further inspiration, read reports that were resolved successfully, http://stackoverflow.com/questions/how-to-ask and http://whathaveyoutried.com/. \ No newline at end of file +* For further inspiration, read reports that were resolved successfully, http://www.chiark.greenend.org.uk/~sgtatham/bugs.html, http://stackoverflow.com/questions/how-to-ask and http://whathaveyoutried.com/. \ No newline at end of file From e6d5b4245755f9e3071c01f19cfddee29a28e524 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Wed, 15 Apr 2015 12:19:37 +0200 Subject: [PATCH 084/591] Rename the 'net' installer into 'SDK' installer Much better to state the purpose than the means to achieve it. Signed-off-by: Johannes Schindelin --- Building-Git.md | 10 +++++----- Building-msys2-runtime.md | 4 ++-- 2 files changed, 7 insertions(+), 7 deletions(-) diff --git a/Building-Git.md b/Building-Git.md index 7879d5921df1cc..11fdc522905f58 100644 --- a/Building-Git.md +++ b/Building-Git.md @@ -1,14 +1,14 @@ -We build Git for Windows using an [MSys2](https://msys2.github.io/) based *Git for Windows SDK*. This SDK can be installed via a [net-installer](https://git-for-windows.github.io/#download-sdk) +We build Git for Windows using an [MSys2](https://msys2.github.io/) based *Git for Windows SDK*. This SDK can be installed via the [SDK installer](https://git-for-windows.github.io/#download-sdk) # Installing a build environment -1. Just install the [net-installer](https://git-for-windows.github.io/#download-sdk). +1. Just run the [SDK installer](https://git-for-windows.github.io/#download-sdk). # Build Git -1. An initial `git clone` and `make` should have already occurred when installing the [net-installer](https://git-for-windows.github.io/#download-sdk). +1. An initial `git clone` and `make` should have already occurred when running the [SDK installer](https://git-for-windows.github.io/#download-sdk). -2. Open the *Git for Windows SDK* *MinGW* shell by double clicking either the Shortcut on the desktop `Git SDK 32-bit.lnk` or by double clicking `mingw32_shell.bat` in the install folder. That is `Git SDK 64-bit.lnk` and `mingw64_shell.bat` for the `64bit` [net-installer](https://git-for-windows.github.io/#download-sdk). +2. Open the *Git for Windows SDK* *MinGW* shell by double clicking either the Shortcut on the desktop `Git SDK 32-bit.lnk` or by double clicking `mingw32_shell.bat` in the install folder. That is `Git SDK 64-bit.lnk` and `mingw64_shell.bat` for the `64bit` [SDK installer](https://git-for-windows.github.io/#download-sdk). 2. Change directory to the initial clone: `cd /usr/src/git`. @@ -31,4 +31,4 @@ As before: ```bash cd /usr/src/git/t /usr/bin/time prove -j 5 --state=failed,save ./t[0-9]*.sh -``` \ No newline at end of file +``` diff --git a/Building-msys2-runtime.md b/Building-msys2-runtime.md index 44dd9dcc240a3a..a09e2e15556788 100644 --- a/Building-msys2-runtime.md +++ b/Building-msys2-runtime.md @@ -1,6 +1,6 @@ # Installing a build environment -1. Just install the [net-installer](https://git-for-windows.github.io/#download-sdk). +1. Just run the [SDK installer](https://git-for-windows.github.io/#download-sdk). # Build `msys2-⁠runtime` @@ -24,4 +24,4 @@ To actually build the `msys-2.0.dll`, switch to `src/build--pc-msys/ # Related: building/rebuilding Bash -The process to rebuild the `Bash` is very similar to the `msys2-runtime` one; You will just need to work in the `src/bash-/` subdirectory of `/usr/src/MSYS2-packages/bash/` (both the sources and the generated `bash.exe` live there). Bash also requires all Bash instances to be exited before the executable is replaced by the new one. And like with the msys2-runtime, you will **want** to make a backup copy of the old `bash.exe`. \ No newline at end of file +The process to rebuild the `Bash` is very similar to the `msys2-runtime` one; You will just need to work in the `src/bash-/` subdirectory of `/usr/src/MSYS2-packages/bash/` (both the sources and the generated `bash.exe` live there). Bash also requires all Bash instances to be exited before the executable is replaced by the new one. And like with the msys2-runtime, you will **want** to make a backup copy of the old `bash.exe`. From fe32e289fc10f6a596cfe33e918835b414a177ed Mon Sep 17 00:00:00 2001 From: dscho Date: Wed, 15 Apr 2015 17:18:20 +0200 Subject: [PATCH 085/591] Mention that the patches should be signed off on --- How-to-participate.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/How-to-participate.md b/How-to-participate.md index 51eac4fbb05a28..f1ee8cab0b12fe 100644 --- a/How-to-participate.md +++ b/How-to-participate.md @@ -13,3 +13,5 @@ A lot of documentation wants to be written, still. A good place is [the Git for Download [the SDK](http://git-for-windows.github.io/#download-sdk) and build Git. TODO: mention good practices to develop using Eclipse, MSVC, command-line, gdb, test suite (`set -x` and similar tricks) + +Please also sign off your work, as [asked by the Git project](https://github.com/git/git/blob/v2.3.5/Documentation/SubmittingPatches#L234-L286) \ No newline at end of file From 61ad6d18517c44a20393333d3e7cf017fb4326d0 Mon Sep 17 00:00:00 2001 From: dscho Date: Wed, 15 Apr 2015 17:21:21 +0200 Subject: [PATCH 086/591] Add a link to the "Building Git" page --- How-to-participate.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/How-to-participate.md b/How-to-participate.md index f1ee8cab0b12fe..248b7c1d4ee493 100644 --- a/How-to-participate.md +++ b/How-to-participate.md @@ -10,7 +10,7 @@ A lot of documentation wants to be written, still. A good place is [the Git for # Fix bugs or add features in the Git code itself -Download [the SDK](http://git-for-windows.github.io/#download-sdk) and build Git. +Download [the SDK](http://git-for-windows.github.io/#download-sdk) and build Git. Also have a look at [this page](https://github.com/git-for-windows/git/wiki/Building-Git) for tips and tricks revolving around building and debugging Git. TODO: mention good practices to develop using Eclipse, MSVC, command-line, gdb, test suite (`set -x` and similar tricks) From 26084d638f8a0e1458f060fabc33deaf8fbe4b75 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Wed, 15 Apr 2015 17:23:41 +0200 Subject: [PATCH 087/591] Move the remaining TODOs to the 'Building Git' page We should really describe how to use Eclipse or MSVC in that page... Signed-off-by: Johannes Schindelin --- Building-Git.md | 2 ++ How-to-participate.md | 4 +--- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/Building-Git.md b/Building-Git.md index 11fdc522905f58..6427c4dc3044b2 100644 --- a/Building-Git.md +++ b/Building-Git.md @@ -32,3 +32,5 @@ As before: cd /usr/src/git/t /usr/bin/time prove -j 5 --state=failed,save ./t[0-9]*.sh ``` + +TODO: mention good practices to develop using Eclipse, MSVC diff --git a/How-to-participate.md b/How-to-participate.md index 248b7c1d4ee493..cd39f2b4c2612e 100644 --- a/How-to-participate.md +++ b/How-to-participate.md @@ -12,6 +12,4 @@ A lot of documentation wants to be written, still. A good place is [the Git for Download [the SDK](http://git-for-windows.github.io/#download-sdk) and build Git. Also have a look at [this page](https://github.com/git-for-windows/git/wiki/Building-Git) for tips and tricks revolving around building and debugging Git. -TODO: mention good practices to develop using Eclipse, MSVC, command-line, gdb, test suite (`set -x` and similar tricks) - -Please also sign off your work, as [asked by the Git project](https://github.com/git/git/blob/v2.3.5/Documentation/SubmittingPatches#L234-L286) \ No newline at end of file +Please also sign off your work, as [asked by the Git project](https://github.com/git/git/blob/v2.3.5/Documentation/SubmittingPatches#L234-L286) From 383faaf68138c5e3f7dd7356e59f1ce8e5861d54 Mon Sep 17 00:00:00 2001 From: Sebastian Schuberth Date: Thu, 16 Apr 2015 17:16:58 +0200 Subject: [PATCH 088/591] Created Continuous Integration (CI) (markdown) --- Continuous-Integration-(CI).md | 14 ++++++++++++++ 1 file changed, 14 insertions(+) create mode 100644 Continuous-Integration-(CI).md diff --git a/Continuous-Integration-(CI).md b/Continuous-Integration-(CI).md new file mode 100644 index 00000000000000..57c00e4aa2f81c --- /dev/null +++ b/Continuous-Integration-(CI).md @@ -0,0 +1,14 @@ +## Foreword + +We have a [public Jenkins CI server](https://dscho.cloudapp.net/) running on Windows Server 2012 R2 in [Microsoft Azure](http://azure.microsoft.com/). Anonymous users are able to see the job configurations, but not to edit them. + +## Git SDK installer builds + +The job that builds snapshots of the latest SDK installer is [here](https://dscho.cloudapp.net/job/gfw-msys2-build-sdk-installer/). Use this installer *only* if you depend on the latest fixes in the installer itself. Otherwise please wait for the [latest release](https://github.com/git-for-windows/build-extra/releases/latest). + +If you just want to update your existing SDK installation, you can do so by running `pacman -Syu` from Git Bash. + +## Git user installer builds + +The job that builds snapshots of the latest user is [here](https://dscho.cloudapp.net/job/gfw-msys2-build-user-installer/). Use this installer *only* if you need to verify that any bugs are fixed. Do *not* use the snapshot for production use but please wait for the [latest release](https://github.com/git-for-windows/git/releases/latest) instead. + From 7369f45200800a30d27a3ecb225fdc28881ad574 Mon Sep 17 00:00:00 2001 From: Jan Hudec Date: Wed, 22 Apr 2015 11:23:51 +0200 Subject: [PATCH 089/591] Mention workarounds for things not working in mintty --- FAQ.md | 14 ++++++++++++++ 1 file changed, 14 insertions(+) diff --git a/FAQ.md b/FAQ.md index 86f0b29e423d08..48da40b525e176 100644 --- a/FAQ.md +++ b/FAQ.md @@ -1,3 +1,17 @@ ## What is the relationship between *Git for Windows* and *msysGit*? *Git for Windows* used to be developed using the development environment called "msysGit", but roughly coinciding with Git 2.1, msysGit was superseded by a new development environment: the [Git for Windows SDK](https://github.com/git-for-windows/build-extra/releases). + + +## Some native console programs don't work when run from Git Bash. How to fix it? + +*Git for Windows* defaults to using [mintty](https://code.google.com/p/mintty/) terminal. Compared to default Windows console host, it provides normal multi-line cut&paste, working resizing, defaults to unicode font and avoids some bugs in the default console host. However it does not present itself as console to native applications (those *not* built with MSys or Cygwin), so in these applications: + + * Non-ascii output may be corrupted due to mismatch in character sets (MSys and Cygwin use utf-8 while Windows will fall back to the legacy dos codepages in this case). + * Interactive and full-screen applications won't work at all. + +There are several methods for working around these problems: + + * Run programs that have problems using the [`winpty`](https://github.com/rprichard/winpty) utility. This allows you to keep using the nicer mintty terminal, but can become unwieldy if you need the workaround for many programs. + * Modify the shortcut for Git Bash to run `bash` directly without `mintty` so it uses the default console host and configure it for "Quick Edit", reasonable size and scroll-back and suitable unicode font. You'll still have to live with the other quirks of console host. + * Install and use [ConEmu](http://conemu.github.io/). \ No newline at end of file From e88a94cd4ad1fb32af6586fb147fac4686c7f27e Mon Sep 17 00:00:00 2001 From: nalla Date: Tue, 28 Apr 2015 14:36:43 +0200 Subject: [PATCH 090/591] Added link to the governance model --- How-to-participate.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/How-to-participate.md b/How-to-participate.md index cd39f2b4c2612e..3908cdfc6aa4f3 100644 --- a/How-to-participate.md +++ b/How-to-participate.md @@ -1,4 +1,4 @@ -There are several ways to participate in the Git for Windows project: +There are several ways to participate in the Git for Windows project. But first off, have a look at the [governance model](http://git-for-windows.github.io/governance-model.html) of the project. # Help users From abd89810390d5982b11e7ac90e52283410f07b53 Mon Sep 17 00:00:00 2001 From: Robert Dailey Date: Mon, 4 May 2015 09:25:51 -0500 Subject: [PATCH 091/591] Add "make install" step to instructions for the noobs (like myself!) --- Building-Git.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Building-Git.md b/Building-Git.md index 6427c4dc3044b2..8cb326de209f5b 100644 --- a/Building-Git.md +++ b/Building-Git.md @@ -12,7 +12,7 @@ We build Git for Windows using an [MSys2](https://msys2.github.io/) based *Git f 2. Change directory to the initial clone: `cd /usr/src/git`. -4. (Optional) build Git: `make`. +4. (Optional) build Git: `make`, then install it: `make install` 5. Run the test suite: `make test`. If you are a fan of statistics, you can use the following `prove` invocation to run the testsuite. But first we have to change to the test directory with the command `cd t`. After that you can issue `/usr/bin/time prove -j 15 --state=failed,save ./t[0-9]*.sh`. If *15* threads are too many for your system, you can provide the number of threads via the `-j ` (j for jobs) parameter. From 960752619f008de33deed33c747a28465e6120b6 Mon Sep 17 00:00:00 2001 From: dscho Date: Mon, 18 May 2015 10:46:39 +0200 Subject: [PATCH 092/591] Updated How to participate (markdown) --- How-to-participate.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/How-to-participate.md b/How-to-participate.md index 3908cdfc6aa4f3..998b27ebb357ef 100644 --- a/How-to-participate.md +++ b/How-to-participate.md @@ -1,4 +1,4 @@ -There are several ways to participate in the Git for Windows project. But first off, have a look at the [governance model](http://git-for-windows.github.io/governance-model.html) of the project. +There are several ways to participate in the Git for Windows project. First off, have a look at the [governance model](http://git-for-windows.github.io/governance-model.html) of the project. # Help users From fb84d3f785aeb4c3596e6bd1c6ac1afd62c024df Mon Sep 17 00:00:00 2001 From: Sushovan Mukherjee Date: Wed, 20 May 2015 02:09:25 +0530 Subject: [PATCH 093/591] Git Bash Here (Properly) --- Git-Bash-Here-(Properly).md | 62 +++++++++++++++++++++++++++++++++++++ 1 file changed, 62 insertions(+) create mode 100644 Git-Bash-Here-(Properly).md diff --git a/Git-Bash-Here-(Properly).md b/Git-Bash-Here-(Properly).md new file mode 100644 index 00000000000000..0c1d6f6540823f --- /dev/null +++ b/Git-Bash-Here-(Properly).md @@ -0,0 +1,62 @@ +How to add Git Bash Here properly: + +Create a batch file named bash_here.bat in installed directory and contents should be: + +`:` + +`@echo off` + +`set MSYSTEM=MINGW64` + +`set curpath="."` + +`if NOT 'x%1' == 'x' set curpath=%1` + +`start %~dp0usr\bin\mintty.exe -i /mingw64/share/git/git-for-windows.ico -t "MSYS2 Bash Here" -w normal /usr/bin/bash -lc 'cd "$(cygpath %curpath%)"; export CHERE_INVOKING=1; exec bash --login -i'` + +Then you need to add in regedit: + +[HKEY_CLASSES_ROOT\Directory\Background\shell\msys2] + +@="MSYS2 Bash here" + +"Icon"="C:\\git-sdk-64\\mingw64\\share\\git\\git-for-windows.ico" + + +[HKEY_CLASSES_ROOT\Directory\Background\shell\msys2\command] + +@="C:\\git-sdk-64\\bash_here.bat \"%V\"" + + +[HKEY_CLASSES_ROOT\Directory\Background\shell\msys2_git_gui] + +"Icon"="C:\\git-sdk-64\\mingw64\\share\\git\\git-for-windows.ico" + +@="MSYS2 Git GUI" + +[HKEY_CLASSES_ROOT\Directory\Background\shell\msys2_git_gui\command] + +@="C:\\git-sdk-64\\usr\\bin\\bash.exe -lc 'cd \"$(cygpath \"%V\")\"; export CHERE_INVOKING=1; exec git gui'" + + +[HKEY_CLASSES_ROOT\Directory\shell\msys2] + +@="MSYS2 Bash here" + +"Icon"="C:\\git-sdk-64\\mingw64\\share\\git\\git-for-windows.ico" + +[HKEY_CLASSES_ROOT\Directory\shell\msys2\command] + +@="C:\\git-sdk-64\\bash_here.bat \"%V\"" + + +[HKEY_CLASSES_ROOT\Directory\shell\msys2_git_gui] + +@="MSYS2 Git GUI" + +"Icon"="C:\\msysgit\\share\\resources\\git.ico" + + +[HKEY_CLASSES_ROOT\Directory\shell\msys2_git_gui\command] + +@="C:\\git-sdk-64\\usr\\bin\\bash.exe -lc 'cd \"$(cygpath \"%V\")\"; export CHERE_INVOKING=1; exec git gui'" From 20f48ea73d913537c0a9be0946c63ede0d99265b Mon Sep 17 00:00:00 2001 From: dscho Date: Mon, 25 May 2015 11:30:17 +0200 Subject: [PATCH 094/591] Initial copy-edit of https://github.com/msysgit/msysgit/wiki/Vagrant --- Vagrant.md | 49 +++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 49 insertions(+) create mode 100644 Vagrant.md diff --git a/Vagrant.md b/Vagrant.md new file mode 100644 index 00000000000000..8940a93d730349 --- /dev/null +++ b/Vagrant.md @@ -0,0 +1,49 @@ +# Introduction + +[Vagrant](https://www.vagrantup.com/) is a modern way to define the requirements of a project. In the case of [Git for Windows](http://git-for-windows.github.io/), it allows us to set up a minimal virtual Linux machine that makes it easy to run the same revision of Git on Windows as well as on Linux without much effort. + +**Note**: while Vagrant makes things easy, quite a bit of bandwidth is required for the setup (roughly a gigabyte will be downloaded in total). + +# How to install + +1. Download and install [VirtualBox](https://www.virtualbox.org) +2. Download and install [Vagrant](https://www.vagrantup.com/) +3. Install the [Git SDK](http://git-for-windows.github.io/#download-sdk) +4. Run `vagrant up` in the `/usr/src/git` directory +5. Run `vagrant ssh` + +Note that the prompt shows that the current directory in the ssh session inside the virtual machine is `/vagrant/` and that the files in that directory are suspiciously identical to the `/usr/src/git/` directory in your Git SDK installation. This is not by accident. In fact, the `/vagrant/` directory inside the virtual machine *is* the `/usr/src/git` directory of the hosting Git SDK. Note: This implies that the file names are case-insensitive, still, even if running inside a Linux VM. + +To compile and install Git, you will have to run `make clean` first because *Git* will have built *Windows* binaries in the same directory (when we will need *Linux* binaries inside the virtual machine started by Vagrant). After calling `make install` and `export PATH=$HOME/bin:$PATH` you will be able to run the Git version built from the source files in `/vagrant/git/`. + +# Why? + +Git was born on Linux. Over the years, it has become more and more platform-independent, but still support for Linux outshines support for every other platform, including Windows. Therefore it is preferable under certain circumstances to run Git inside Linux in a virtual machine, for example + +* for finding out whether a bug is Windows-specific or not +* for performance (Linux' filesystem and memory management is better than Windows') +* for verifying that Git for Windows' source code compiles correctly with Linux, too +* etc + +# Known problems + +* The Linux version of Git was designed to run on Linux file systems. Vagrant exposes Git for Windows' source code directory as `/vagrant/` but of course it cannot make up for the Windows file system's lack of support for Unix-style file permissions nor case-sensitive file names. As a consequence, quite a few of the unit tests fail when run in-place. +* Git cannot be built with Perl's MakeMaker using Vagrant: it tries to create files with double colons in their name (e.g. `Git::I18N.3pm`) which is not allowed on Windows file systems. +* If the Git SDK was started inside a VirtualBox (e.g. to be able to test Git for Windows even on a Linux/MacOSX laptop), VirtualBox will not be able to start the virtual machine (with an error message *VERR_VMX_NO_VMX*). This is a [known problem with VirtualBox](https://www.virtualbox.org/ticket/4032). +* `git svn` is *very* slow. Actually, `git svn` is *not* very slow. But it is if you run it inside a directory under `/vagrant/`. The reason is that Linux' file system performance cannot come to full play when accessing `/vagrant/` -- which really is the host's directory managed by Windows. If you want to benefit from Linux' performance characteristics, you will have to perform the time-critical operations either in `/home/vagrant/` inside the virtual machine, or inside a `tmpfs`. + +# Tips & Tricks + +## Use `tmpfs` + +Linux offers a plethora of file systems optimized for different use cases. One of them is [`tmpfs`](https://www.kernel.org/doc/Documentation/filesystems/tmpfs.txt), a RAM-based file system which keeps all files in virtual memory and is therefore very fast (but does not persist any of the data to disk). + +Using such a file system can speed up Git operations quite substantially, in particular when performing disk-intensive operations, such as `git filter-branch`, `git gc` or `git svn`. It is very easy to create a `tmpfs`-backed file system: + +```bash +mkdir -p $HOME/tmp +sudo mount -t tmpfs -o size=10G tmpfs $HOME/tmp +cd $HOME/tmp +``` + +You will want to clone projects into that `$HOME/tmp/` directory so that the I/O intensive operations benefit fully from using Vagrant. \ No newline at end of file From 840e523152852a3da18756d9c0e0795588217722 Mon Sep 17 00:00:00 2001 From: dscho Date: Tue, 9 Jun 2015 12:38:06 +0000 Subject: [PATCH 095/591] Redirect to the ticket --- Git-Bash-Here-(Properly).md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/Git-Bash-Here-(Properly).md b/Git-Bash-Here-(Properly).md index 0c1d6f6540823f..2cb84be68b381d 100644 --- a/Git-Bash-Here-(Properly).md +++ b/Git-Bash-Here-(Properly).md @@ -1,3 +1,5 @@ +***NOTE***: This page probably hints at a bug, tentative ticket [here](https://github.com/git-for-windows/git/issues/184). The following instructions should not be followed, but the bug should be fixed instead: + How to add Git Bash Here properly: Create a batch file named bash_here.bat in installed directory and contents should be: From a8af1bfa2661f42e14fccea28f495302fbc87631 Mon Sep 17 00:00:00 2001 From: dscho Date: Tue, 9 Jun 2015 13:14:22 +0000 Subject: [PATCH 096/591] Describe how to build packages from locally-patched source code --- Package-management.md | 19 ++++++++++++++++++- 1 file changed, 18 insertions(+), 1 deletion(-) diff --git a/Package-management.md b/Package-management.md index b343f44b08478f..458083aa19d8a6 100644 --- a/Package-management.md +++ b/Package-management.md @@ -72,10 +72,27 @@ makepkg-mingw -s To build MSys packages, you need to start the `MSys` shell (which sets `MSYSTEM=MSYS` before running the Bash), clone the [`MSYS2-packages`](https://github.com/git-for-windows/MSYS2-packages) repository (recommended location: `/usr/src/MSYS2-packages`), `cd` to the appropriate subdirectory and call -```bash +```bas makepkg -s ``` +### Build packages from locally-patched sources + +When testing Pull Requests or debugging certain issues, it is convenient to build packages from source code other than the canonical one listed in the `PKGBUILD` file. This can be achieved by switching to the subdirectory of `/usr/src/MINGW-packages` or `/usr/src/MSYS2-packages`, respectively, corresponding to the package you want to build, ensure that the `src/` directory is populated (and call `makepkg-mingw --nobuild -s` or `makepkg --nobuild -s` otherwise), then patch the source code in the `src/` subdirectory and after that call + +```bash +makepkg-mingw --noextract --noprepare +``` + +or + + +```bash +makepkg --noextract --noprepare +``` + +to build the package. + ### More details about rebuilding packages The `makepkg` script is part of the `pacman` package itself. It expects a [`PKGBUILD`](https://wiki.archlinux.org/index.php/PKGBUILD) file in the current directory that contains metadata about the package and functions specifying how to prepare the source code, build the executables, and package all the files. From 6b2030a974488051e6275f391f67fd915b6be1c6 Mon Sep 17 00:00:00 2001 From: dscho Date: Thu, 11 Jun 2015 16:12:32 +0000 Subject: [PATCH 097/591] Destroyed Git Bash Here (Properly) (markdown) --- Git-Bash-Here-(Properly).md | 64 ------------------------------------- 1 file changed, 64 deletions(-) delete mode 100644 Git-Bash-Here-(Properly).md diff --git a/Git-Bash-Here-(Properly).md b/Git-Bash-Here-(Properly).md deleted file mode 100644 index 2cb84be68b381d..00000000000000 --- a/Git-Bash-Here-(Properly).md +++ /dev/null @@ -1,64 +0,0 @@ -***NOTE***: This page probably hints at a bug, tentative ticket [here](https://github.com/git-for-windows/git/issues/184). The following instructions should not be followed, but the bug should be fixed instead: - -How to add Git Bash Here properly: - -Create a batch file named bash_here.bat in installed directory and contents should be: - -`:` - -`@echo off` - -`set MSYSTEM=MINGW64` - -`set curpath="."` - -`if NOT 'x%1' == 'x' set curpath=%1` - -`start %~dp0usr\bin\mintty.exe -i /mingw64/share/git/git-for-windows.ico -t "MSYS2 Bash Here" -w normal /usr/bin/bash -lc 'cd "$(cygpath %curpath%)"; export CHERE_INVOKING=1; exec bash --login -i'` - -Then you need to add in regedit: - -[HKEY_CLASSES_ROOT\Directory\Background\shell\msys2] - -@="MSYS2 Bash here" - -"Icon"="C:\\git-sdk-64\\mingw64\\share\\git\\git-for-windows.ico" - - -[HKEY_CLASSES_ROOT\Directory\Background\shell\msys2\command] - -@="C:\\git-sdk-64\\bash_here.bat \"%V\"" - - -[HKEY_CLASSES_ROOT\Directory\Background\shell\msys2_git_gui] - -"Icon"="C:\\git-sdk-64\\mingw64\\share\\git\\git-for-windows.ico" - -@="MSYS2 Git GUI" - -[HKEY_CLASSES_ROOT\Directory\Background\shell\msys2_git_gui\command] - -@="C:\\git-sdk-64\\usr\\bin\\bash.exe -lc 'cd \"$(cygpath \"%V\")\"; export CHERE_INVOKING=1; exec git gui'" - - -[HKEY_CLASSES_ROOT\Directory\shell\msys2] - -@="MSYS2 Bash here" - -"Icon"="C:\\git-sdk-64\\mingw64\\share\\git\\git-for-windows.ico" - -[HKEY_CLASSES_ROOT\Directory\shell\msys2\command] - -@="C:\\git-sdk-64\\bash_here.bat \"%V\"" - - -[HKEY_CLASSES_ROOT\Directory\shell\msys2_git_gui] - -@="MSYS2 Git GUI" - -"Icon"="C:\\msysgit\\share\\resources\\git.ico" - - -[HKEY_CLASSES_ROOT\Directory\shell\msys2_git_gui\command] - -@="C:\\git-sdk-64\\usr\\bin\\bash.exe -lc 'cd \"$(cygpath \"%V\")\"; export CHERE_INVOKING=1; exec git gui'" From 8e5d9ac6c91f12fd3d553e1bd3428a8130758a5c Mon Sep 17 00:00:00 2001 From: Ciaran Jessup Date: Tue, 16 Jun 2015 09:07:38 +0100 Subject: [PATCH 098/591] Created Auto launching ssh-agent when git starts (markdown) --- Auto-launching-ssh-agent-when-git-starts.md | 60 +++++++++++++++++++++ 1 file changed, 60 insertions(+) create mode 100644 Auto-launching-ssh-agent-when-git-starts.md diff --git a/Auto-launching-ssh-agent-when-git-starts.md b/Auto-launching-ssh-agent-when-git-starts.md new file mode 100644 index 00000000000000..3b85b339707dea --- /dev/null +++ b/Auto-launching-ssh-agent-when-git-starts.md @@ -0,0 +1,60 @@ +If you want your passphrase to be 'remembered' for a session (or configurable timeout period) you will need to setup an ssh-agent process to handle this key. Github provides excellent instructions for this here: https://help.github.com/articles/working-with-ssh-key-passphrases/#auto-launching-ssh-agent-on-msysgit + +**However** if you follow these instructions you will be unable to install git for windows 2.x (it will hang waiting for the ssh-add.exe process to be killed.) + +To avoid this issue, if you use the following script (based on that provided above) you will be able to install and upgrade git for windows 2.x + + # Note: ~/.ssh/environment should not be used, as it + # already has a different purpose in SSH. + + env=~/.ssh/agent.env + + # Note: Don't bother checking SSH_AGENT_PID. It's not used + # by SSH itself, and it might even be incorrect + # (for example, when using agent-forwarding over SSH). + + agent_is_running() { + if [ "$SSH_AUTH_SOCK" ]; then + # ssh-add returns: + # 0 = agent running, has keys + # 1 = agent running, no keys + # 2 = agent not running + ssh-add -l >/dev/null 2>&1 || [ $? -eq 1 ] + else + false + fi + } + + agent_has_keys() { + ssh-add -l >/dev/null 2>&1 + } + + agent_load_env() { + . "$env" >/dev/null + } + + agent_start() { + (umask 077; ssh-agent >"$env") + . "$env" >/dev/null + } + + # We only want to fire up ssh-agent when in an interactive session. + case "$-" in + *i*) + if ! agent_is_running; then + agent_load_env + fi + + # if your keys are not stored in ~/.ssh/id_rsa or ~/.ssh/id_dsa, you'll need + # to paste the proper path after ssh-add + if ! agent_is_running; then + agent_start + ssh-add + elif ! agent_has_keys; then + ssh-add + fi + + unset env + ;; + esac + From 98d521f33ff89acf4583c55fd553041c16aa136a Mon Sep 17 00:00:00 2001 From: bviktor Date: Thu, 18 Jun 2015 13:50:45 +0200 Subject: [PATCH 099/591] Add info about finding the corresponding package for a file --- Package-management.md | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/Package-management.md b/Package-management.md index 458083aa19d8a6..8281d7f01edccd 100644 --- a/Package-management.md +++ b/Package-management.md @@ -52,6 +52,12 @@ To list the contents of a package, call pacman -Ql ``` +To find out what package a file belongs to, call + +```bash +pacman -Qo +``` + # Technical details ## Rebuild packages From 3bf034384bf24503211f3ad3d10a6829711387a4 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=EB=A7=88=EB=88=84=EC=97=98?= Date: Thu, 25 Jun 2015 09:35:59 +0200 Subject: [PATCH 100/591] Added footer to the wiki --- _Footer.md | 1 + 1 file changed, 1 insertion(+) create mode 100644 _Footer.md diff --git a/_Footer.md b/_Footer.md new file mode 100644 index 00000000000000..bfd159f1facf6b --- /dev/null +++ b/_Footer.md @@ -0,0 +1 @@ +This is the _Git for Windows_ wiki. See contribute on how to participate. \ No newline at end of file From 765e09cbc56f2d2fcaea9366c5a09bf7622d1573 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=EB=A7=88=EB=88=84=EC=97=98?= Date: Thu, 25 Jun 2015 09:37:05 +0200 Subject: [PATCH 101/591] Added link to participation site --- _Footer.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/_Footer.md b/_Footer.md index bfd159f1facf6b..e206dc2d0d37d3 100644 --- a/_Footer.md +++ b/_Footer.md @@ -1 +1 @@ -This is the _Git for Windows_ wiki. See contribute on how to participate. \ No newline at end of file +This is the _Git for Windows_ wiki. See [how to participate](https://github.com/git-for-windows/git/wiki/How-to-participate). \ No newline at end of file From 4e6282302f907b79bc3d0a349a450f9e362f202a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=EB=A7=88=EB=88=84=EC=97=98?= Date: Thu, 25 Jun 2015 09:59:16 +0200 Subject: [PATCH 102/591] Adding about section --- Home.md | 27 +++++++++++++++++++++++++-- 1 file changed, 25 insertions(+), 2 deletions(-) diff --git a/Home.md b/Home.md index b03fe398aa7250..f840a69cc11f00 100644 --- a/Home.md +++ b/Home.md @@ -1,3 +1,26 @@ -This is the Git for Windows wiki. It looks more technical than [our home page](https://git-for-windows.github.io/) because it is the place where you can contribute to the documentation about Git for Windows. +# Introduction +The _Git for Windows_ wiki. It looks more technical than [our home page](https://git-for-windows.github.io/) because it is the place where *you* [can contribute](https://github.com/git-for-windows/git/wiki/How-to-participate) to the documentation about _Git for Windows_. -If you need inspiration what you could write about: document your common work flows. Write a tutorial how to start coding Git for Windows, how to run the test suite. Write a tutorial how to debug a failing test. Write about something you would have wished you had known about Git for Windows a long time ago. \ No newline at end of file +## About +_Git for Windows_ is very different from _Git_ for almost everything else in one important respect: Windows does not provide the *POSIX* infrastructure Git expects. + +Therefore, it always had to ship with much more than any other Git distribution: provide a `bash`, a `perl`, many *POSIX* tools such as `sed`, `awk`, `tr`, etc. + +Git for Windows 1.x did that by starting off from an [MSys](http://www.mingw.org/wiki/msys) installation and just packaging all the required files as-are. _MSys_ did not sport any package manager at the time, so all of the updates were quite manual, and some of the components we shipped were not even part of _MSys_ -- such as `msmtp` or `WhoUses` -- so we had to compile them from scratch, and maintain those components ourselves. + +This became really too tedious, so much so that there was not enough time to provide updated Git for Windows installers regularly. + +At some stage, it became obvious that there needs to be a better solution. [@sschuberth](https://github.com/sschuberth) had already started a separate project to leverage the package manager that _MSys_ had introduced at that stage, `mingw-get`. However, it turned out that the packages were not maintained all that well, and besides, _MSys_' runtime had not been kept up-to-date with [Cygwin](https://www.cygwin.com/), and was falling behind in terms of features and support. + +In a two-hour Skype session about the course of _Git for Windows_ [@dscho](https://github.com/dscho), [@t-b](https://github.com/t-b) and [@sschuberth](https://github.com/sschuberth) decided to give [MSys2](https://msys2.github.io/) a whirl. _MSys2_ was started with the idea to restart the _MSys_ project, frequently updating with _Cygwin_ and just keeping the spirit of _MSys_ to provide a very stripped-down *POSIX* layer, essentially a bare-minimum version of _Cygwin_. _MSys2_ also sports a package manager (`pacman`) and keeps those packages up-to-date very well. Another bonus: _MSys2_ is available for `64-bit` in addition to `32-bit`, while _MSys_ was stuck with `32-bit`. + +Thanks to sponsoring of _GitHub_, [@dscho](https://github.com/dscho) could afford to spend the time to investigate the possibilities with _MSys2_. It turned out that _MSys2_ already provided most of the parts needed, and would make maintenance much, much easier. [@dscho](https://github.com/dscho) (and others too) really spent an insane amount of time (thanks GitHub!) to get everything up to speed, even fixing a couple of long-standing bugs in _Git for Windows_. It essentially came down to modifying the `msys2-runtime` to _Git for Windows_ needs. The rest is basically upstream _MSys2_ architecture. + +And yes, the idea is still the same as the original one: Update the _MSys2_ setup, together with a _Git_ package built from _Git for Windows_' source code, then bundle the relevant files together with a couple of extra files into an installer. Then I sign it and upload it. And that is _Git for Windows_ 2.x. + +Now, keep in mind that _MSys2_ and Linux (The original target for _Git_'s distribution) are very different beasts. Their distributions might include packages that are built from the same source code (i.e. the `binutils`, `gcc` or `bash` package), but the runtime is very, very different: _MSys2_'s runtime is a stripped-down, slightly modified _Cygwin_ runtime running on top of the Windows kernel, while Linux' runtime is the Linux kernel, running as a separate OS altogether. + +So if you are missing some packages - feel free to start making one. This is Open Source, however, so everybody interested and capable enough can contribute whatever they need to address their needs. And that includes you: you could imitate e.g. [a simple `PKGBUILD` file](https://github.com/Alexpux/MINGW-packages/blob/master/mingw-w64-assimp-git/PKGBUILD) to build a new package e.g. `msmtp`, the component that _Git for Windows_ 1.x uses to support `sendemail`. Then open a Pull Request so that _Git for Windows_ can ship it. Our documentation will be helpful in that endeavor: [package-management](https://github.com/git-for-windows/git/wiki/Package-management), in particular [package-management#rebuild-packages](https://github.com/git-for-windows/git/wiki/Package-management#rebuild-packages). + +# Start documenting +If you need inspiration what you could write about: document your common work flows. Write a tutorial how to start coding _Git for Windows_, how to run the test suite. Write a tutorial how to debug a failing test. Write about something you would have wished you had known about Git for Windows a long time ago. \ No newline at end of file From 6169d083998192c62f7020d019b26c6d57310999 Mon Sep 17 00:00:00 2001 From: Sebastian Schuberth Date: Thu, 25 Jun 2015 13:11:53 +0200 Subject: [PATCH 103/591] Updated Home (markdown) --- Home.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Home.md b/Home.md index f840a69cc11f00..cce3ec3d5e56ad 100644 --- a/Home.md +++ b/Home.md @@ -10,7 +10,7 @@ Git for Windows 1.x did that by starting off from an [MSys](http://www.mingw.org This became really too tedious, so much so that there was not enough time to provide updated Git for Windows installers regularly. -At some stage, it became obvious that there needs to be a better solution. [@sschuberth](https://github.com/sschuberth) had already started a separate project to leverage the package manager that _MSys_ had introduced at that stage, `mingw-get`. However, it turned out that the packages were not maintained all that well, and besides, _MSys_' runtime had not been kept up-to-date with [Cygwin](https://www.cygwin.com/), and was falling behind in terms of features and support. +At some stage, it became obvious that there needs to be a better solution. [@sschuberth](https://github.com/sschuberth) had already started a [separate project](https://github.com/sschuberth/gfw-msys1-sdk) to leverage the package manager that _MSys_ had introduced at that stage, `mingw-get`. However, it turned out that the packages were not maintained all that well, and besides, _MSys_' runtime had not been kept up-to-date with [Cygwin](https://www.cygwin.com/), and was falling behind in terms of features and support. In a two-hour Skype session about the course of _Git for Windows_ [@dscho](https://github.com/dscho), [@t-b](https://github.com/t-b) and [@sschuberth](https://github.com/sschuberth) decided to give [MSys2](https://msys2.github.io/) a whirl. _MSys2_ was started with the idea to restart the _MSys_ project, frequently updating with _Cygwin_ and just keeping the spirit of _MSys_ to provide a very stripped-down *POSIX* layer, essentially a bare-minimum version of _Cygwin_. _MSys2_ also sports a package manager (`pacman`) and keeps those packages up-to-date very well. Another bonus: _MSys2_ is available for `64-bit` in addition to `32-bit`, while _MSys_ was stuck with `32-bit`. From adf0f640d0648994a7cd74a908d93b528140fe9a Mon Sep 17 00:00:00 2001 From: dscho Date: Wed, 15 Jul 2015 12:45:04 +0200 Subject: [PATCH 104/591] Finally explain in a wiki page what is going on when `rebase.exe` needs to be called to rescue --- 32-bit-issues.md | 49 ++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 49 insertions(+) create mode 100644 32-bit-issues.md diff --git a/32-bit-issues.md b/32-bit-issues.md new file mode 100644 index 00000000000000..a87103a1d8171a --- /dev/null +++ b/32-bit-issues.md @@ -0,0 +1,49 @@ +# What is the problem with running Git for Windows in 32-bit mode? + +Note that typically, there is no problem because the solution described [here](#adjusting-msys-20dlls-address-range-manually) is executed preventively upon installation of Git for Windows. + +The problem only resurfaces if a `.dll` has been installed *after* Git for Windows' installation and only if that `.dll` interferes with the address range hard-coded into the MSys2 runtime. + +The simplest solution to fix that problem if it rears its ugly head at all is to switch to the 64-bit version of Git for Windows (the 64-bit address range is so large that MSys2's runtime virtually never has any run-in with another `.dll`). + +The second-simplest solution is to + +# Background + +Git for Windows is not just a version of Git compiled and packaged for yet another Operating System. Many parts of Git are written in script languages (e.g. POSIX shell or Perl) and therefore Git for Windows has to bundle such script interpreters as well. In particular `bash.exe` (which is used by Git for Windows to execute POSIX shell scripts) expects a POSIX environment which is not available on Windows. The Git for Windows project uses [MSys2](https://msys2.github.io/) (essentially a [portable](https://en.wikipedia.org/wiki/Portable_application) version of [Cygwin](https://cygwin.com/)) to provide the POSIX emulation layer. + +## The problem with `fork()` + +One of the most crucial POSIX calls expected by Bash is the `fork()` call. It starts a new process, inheriting the current process' memory contents, file descriptors and other resources. And it has no equivalent in the Win32 API (`fork()`'s closest Win32 relative is `CreateProcess()` which spawns a new process, inheriting nothing at all by default). + +To make it possible to emulate `fork()`, Cygwin -- and therefore MSys2 -- needs to make certain assumptions about its core ("runtime") library called `cygwin1.dll` -- or `msys-2.0.dll`. In particular, it needs to pin it to a known address range to detect in child processes that there is a parent process already, and to copy the relevant data from there. + +That works very well. Until another `.dll` has been loaded into memory already, into a location that interferes with the hard-coded address range of the runtime. It is unfortunately not possible to catch that problem in a user-friendly way because there is no Win32 API call that can ask "has this address range been used by this and that `.dll`?". + +## The symptom of an address range that needs adjusting + +When there is already a `.dll` interfering with MSys2's runtime's hard-coded address range, the user will be greeted by this error message when calling Bash : + +``` +> sh.exe + 0 [main] sh.exe" 17588 handle_exceptions: Exception: STATUS_ACCESS_VIOLATION + 865 [main] sh.exe" 17588 open_stackdumpfile: Dumping stack trace to sh.exe.stackdump +``` + +## Solutions + +There are several ways how to get out of this problem: + +## Upgrade to the 64-bit version of Git for Windows + +The address range available in 64-bit Windows is so large as to virtually guarantee that the address range of the MSys2 runtime never has to be adjusted. This is by far the easiest solution, now that Git for Windows 2.x offers a 64-bit version. + +## Reinstall Git for Windows + +If you cannot switch to 64-bit for any reason, reinstalling Git for Windows will typically fix the problem because it [adjusts the address range preemptively](#adjusting-msys-20dlls-address-range-manually). + +## Adjusting `msys-2.0.dll`'s address range manually + +To fix the problem of address range overlaps, MSys2 offers a utility called `rebase.exe` (which confusingly has nothing at all to do with `git rebase`) to adjust the address range of a given set of `.dll` files. + +Unfortunately the [symptom](#the-symptom-of-an-address-range-that-needs-adjusting) occurs not all that rarely, therefore there is even a script to make `rebase.exe` more convenient to use: `/usr/bin/rebaseall`. This script is meant to be executed via Dash instead of Bash, to avoid chicken-and-egg problems with Bash not being able to run properly unless the address range is already fixed. Typically it is unnecessary to run this script manually because it is run as part of Git for Windows' installation process. If the [symptom](#the-symptom-of-an-address-range-that-needs-adjusting) occurs at some stage long after Git for Windows was installed, reinstalling Git for Windows is the most convenient way to fix it. \ No newline at end of file From ff5ae5dcf6a59da788d1b0db27a30ecadcba0934 Mon Sep 17 00:00:00 2001 From: dscho Date: Wed, 15 Jul 2015 12:46:57 +0200 Subject: [PATCH 105/591] Whoops, complete the introuction --- 32-bit-issues.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/32-bit-issues.md b/32-bit-issues.md index a87103a1d8171a..4187a54bd326c9 100644 --- a/32-bit-issues.md +++ b/32-bit-issues.md @@ -2,11 +2,11 @@ Note that typically, there is no problem because the solution described [here](#adjusting-msys-20dlls-address-range-manually) is executed preventively upon installation of Git for Windows. -The problem only resurfaces if a `.dll` has been installed *after* Git for Windows' installation and only if that `.dll` interferes with the address range hard-coded into the MSys2 runtime. +The problem only resurfaces if a `.dll` has been installed *after* Git for Windows' installation and only if that `.dll` [interferes with the address range hard-coded into the MSys2 runtime](#background). The simplest solution to fix that problem if it rears its ugly head at all is to switch to the 64-bit version of Git for Windows (the 64-bit address range is so large that MSys2's runtime virtually never has any run-in with another `.dll`). -The second-simplest solution is to +The second-simplest solution is to [reinstall Git for Windows](#reinstall-git-for-windows). # Background From 7db46635f905b6736c0bdfefd11a0bc72c4849ba Mon Sep 17 00:00:00 2001 From: dscho Date: Wed, 15 Jul 2015 12:47:59 +0200 Subject: [PATCH 106/591] Make the solutions sub sections of the "solutions" section --- 32-bit-issues.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/32-bit-issues.md b/32-bit-issues.md index 4187a54bd326c9..81d34caf0fdeb2 100644 --- a/32-bit-issues.md +++ b/32-bit-issues.md @@ -34,15 +34,15 @@ When there is already a `.dll` interfering with MSys2's runtime's hard-coded add There are several ways how to get out of this problem: -## Upgrade to the 64-bit version of Git for Windows +### Upgrade to the 64-bit version of Git for Windows The address range available in 64-bit Windows is so large as to virtually guarantee that the address range of the MSys2 runtime never has to be adjusted. This is by far the easiest solution, now that Git for Windows 2.x offers a 64-bit version. -## Reinstall Git for Windows +### Reinstall Git for Windows If you cannot switch to 64-bit for any reason, reinstalling Git for Windows will typically fix the problem because it [adjusts the address range preemptively](#adjusting-msys-20dlls-address-range-manually). -## Adjusting `msys-2.0.dll`'s address range manually +### Adjusting `msys-2.0.dll`'s address range manually To fix the problem of address range overlaps, MSys2 offers a utility called `rebase.exe` (which confusingly has nothing at all to do with `git rebase`) to adjust the address range of a given set of `.dll` files. From a34e4562d20deb671d4521dd551995b299223301 Mon Sep 17 00:00:00 2001 From: dscho Date: Wed, 15 Jul 2015 12:48:52 +0200 Subject: [PATCH 107/591] The "solutions" section is actually not a part of the "background" section --- 32-bit-issues.md | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/32-bit-issues.md b/32-bit-issues.md index 81d34caf0fdeb2..675bdba59cb768 100644 --- a/32-bit-issues.md +++ b/32-bit-issues.md @@ -30,19 +30,19 @@ When there is already a `.dll` interfering with MSys2's runtime's hard-coded add 865 [main] sh.exe" 17588 open_stackdumpfile: Dumping stack trace to sh.exe.stackdump ``` -## Solutions +# Solutions There are several ways how to get out of this problem: -### Upgrade to the 64-bit version of Git for Windows +## Upgrade to the 64-bit version of Git for Windows The address range available in 64-bit Windows is so large as to virtually guarantee that the address range of the MSys2 runtime never has to be adjusted. This is by far the easiest solution, now that Git for Windows 2.x offers a 64-bit version. -### Reinstall Git for Windows +## Reinstall Git for Windows If you cannot switch to 64-bit for any reason, reinstalling Git for Windows will typically fix the problem because it [adjusts the address range preemptively](#adjusting-msys-20dlls-address-range-manually). -### Adjusting `msys-2.0.dll`'s address range manually +## Adjusting `msys-2.0.dll`'s address range manually To fix the problem of address range overlaps, MSys2 offers a utility called `rebase.exe` (which confusingly has nothing at all to do with `git rebase`) to adjust the address range of a given set of `.dll` files. From 437df7bead99d4a4828ffa4ebc3c13d90408a137 Mon Sep 17 00:00:00 2001 From: Robert Dailey Date: Sun, 19 Jul 2015 11:32:33 -0500 Subject: [PATCH 108/591] Simplify the build (make) step --- Building-Git.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Building-Git.md b/Building-Git.md index 8cb326de209f5b..90996065545a81 100644 --- a/Building-Git.md +++ b/Building-Git.md @@ -12,7 +12,7 @@ We build Git for Windows using an [MSys2](https://msys2.github.io/) based *Git f 2. Change directory to the initial clone: `cd /usr/src/git`. -4. (Optional) build Git: `make`, then install it: `make install` +4. (Optional) build Git: `make install` 5. Run the test suite: `make test`. If you are a fan of statistics, you can use the following `prove` invocation to run the testsuite. But first we have to change to the test directory with the command `cd t`. After that you can issue `/usr/bin/time prove -j 15 --state=failed,save ./t[0-9]*.sh`. If *15* threads are too many for your system, you can provide the number of threads via the `-j ` (j for jobs) parameter. From 770e0efdbfc1a15579bcae72ea9967ffc270107c Mon Sep 17 00:00:00 2001 From: dscho Date: Mon, 10 Aug 2015 12:46:38 +0200 Subject: [PATCH 109/591] Mention that it is really important to note use of 32-bit OS or Git --- Issue-reporting-guidelines.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Issue-reporting-guidelines.md b/Issue-reporting-guidelines.md index 5b4d5d823fafb3..00b5b5a3d3b182 100644 --- a/Issue-reporting-guidelines.md +++ b/Issue-reporting-guidelines.md @@ -1,5 +1,5 @@ * Search the existing [open](https://github.com/git-for-windows/git/issues?q=is%3Aopen) and [closed](https://github.com/git-for-windows/git/issues?q=is%3Aclosed) issues. Maybe the bug was already reported? -* Include the output of git --version and the Windows version. In case the issue might depend on the server include its git version and OS version also. +* Include the output of git --version and the Windows version. In case the issue might depend on the server include its git version and OS version also. Of course, if you use a 32-bit OS or 32-bit Git on a 64-bit OS, you really want to mention that, too. * Describe your issue properly. If you spend 30 seconds throwing out a sloppy report, do expect that others will spend exactly the same amount on trying to resolve it. * Include a [Minimal, Complete, and Verifiable example](http://stackoverflow.com/help/mcve) using GitHub Markdown's `codeblock` delimiters. * If your issue stems from a particular repository include its URL. If the repository is proprietary try to create a public test repository showing the same issue. From 1fc8d62b94bd84058d2a348ea8749390e0378e14 Mon Sep 17 00:00:00 2001 From: dscho Date: Mon, 10 Aug 2015 16:14:40 +0200 Subject: [PATCH 110/591] General advice on commit messages --- Good-commits.md | 42 ++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 42 insertions(+) create mode 100644 Good-commits.md diff --git a/Good-commits.md b/Good-commits.md new file mode 100644 index 00000000000000..956e700c3df396 --- /dev/null +++ b/Good-commits.md @@ -0,0 +1,42 @@ +Please note that it is a best practice embraced by us to craft elegant, well-separated commits. Each commit is kind of its own little story, so if you make a typo fix, that is its own commit. If you add documentation, that is another commit. If you have multiple typo fixes, you could consider to put them into the same commit, depending on your taste. + +In short, make sure that commits are logical units of changes. + +# Commit messages + +When it comes to the commit message, it is good practice to avoid repeating what is easily deduced from the code changes. Instead, try to describe ... +- ... the *why* and the *what* rather than the *how*; +- ... aspects of the solved problem or feature, that the reader might not be aware of; +- ... aspects that you would want any reviewer to know in addition to the actual code change. + +If you made a change whose benefit is not obvious from reading the code changes associated with the commit, it is a wonderful idea to outline the benefit in the commit message. + +When the commit is the result of a public discussion, it is good practice to summarize it and then add the hyper link to said discussion. + +If you tried several strategies to solve your problem, you will want to describe what you tried and why it did not work, unless it appears too obvious in hindsight. + +Also important: +- The commit message should always start with a single, short line summarizing the change. +- [Sign off](https://github.com/git/git/blob/v2.5.0/Documentation/SubmittingPatches#L234-L286) on your change. +- Format the commit message to wrap at 76 columns per line. + +A good example for a commit message is [git-for-windows/build-extra@a64fe115](github.com/git-for-windows/build-extra/commit/a64fe115d901cab775c881bd1624218ac28de4d4): + +``` +Install 7-Zip without confirmation if it is missing + +This is to allow unattended CI builds for the SFX installers. Once we have +released a new net-installer for the SDK we can remove the check for 7za +altogether as the SDK ships 7-Zip by default since the previous commit. + +Signed-off-by: Sebastian Schuberth +``` + +Please note how it summarizes nicely *what* the change is about ("Install ... without confirmation") instead describing *how* it does it ("Use --noconfirm" would be a counter example), and how the main body provides the context to understand *why* the change is desirable. + +Further reading on commit messages: + +- http://tbaggery.com/2008/04/19/a-note-about-git-commit-messages.html +- http://gitforteams.com/resources/commit-granularity.html +- http://chris.beams.io/posts/git-commit/ +- http://ablogaboutcode.com/2011/03/23/proper-git-commit-messages-and-an-elegant-git-history/ \ No newline at end of file From 283bf5c23656667a1ce004a0d5687c9a4c65e556 Mon Sep 17 00:00:00 2001 From: akrieger Date: Sat, 15 Aug 2015 14:30:18 -0700 Subject: [PATCH 111/591] Add entry for longpaths support. --- FAQ.md | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/FAQ.md b/FAQ.md index 48da40b525e176..f62b0771e598e1 100644 --- a/FAQ.md +++ b/FAQ.md @@ -14,4 +14,7 @@ There are several methods for working around these problems: * Run programs that have problems using the [`winpty`](https://github.com/rprichard/winpty) utility. This allows you to keep using the nicer mintty terminal, but can become unwieldy if you need the workaround for many programs. * Modify the shortcut for Git Bash to run `bash` directly without `mintty` so it uses the default console host and configure it for "Quick Edit", reasonable size and scroll-back and suitable unicode font. You'll still have to live with the other quirks of console host. - * Install and use [ConEmu](http://conemu.github.io/). \ No newline at end of file + * Install and use [ConEmu](http://conemu.github.io/). + +## I get errors trying to check out files with long path names. +Windows file paths are by default limited to 255 characters. Some repositories may have committed files which contain paths longer than the limit. By default, *Git for Windows* does not support long paths, and will print errors when trying to perform any operation on a long file name. Set the configuration property core.longpaths to true to allow certain Git operations to properly handle these files. See [this wiki page](https://github.com/msysgit/msysgit/wiki/Git-cannot-create-a-file-or-directory-with-a-long-path) for more information. \ No newline at end of file From 3a927f86a3a283e357a2f2e474921ddc0b3bc168 Mon Sep 17 00:00:00 2001 From: dscho Date: Sun, 16 Aug 2015 10:43:09 +0200 Subject: [PATCH 112/591] Copy-edit of https://github.com/msysgit/msysgit/wiki/Git-cannot-create-a-file-or-directory-with-a-long-path --- ...te-a-file-or-directory-with-a-long-path.md | 23 +++++++++++++++++++ 1 file changed, 23 insertions(+) create mode 100644 Git-cannot-create-a-file-or-directory-with-a-long-path.md diff --git a/Git-cannot-create-a-file-or-directory-with-a-long-path.md b/Git-cannot-create-a-file-or-directory-with-a-long-path.md new file mode 100644 index 00000000000000..d43ab6b3988c3c --- /dev/null +++ b/Git-cannot-create-a-file-or-directory-with-a-long-path.md @@ -0,0 +1,23 @@ +# The problem + +Windows does not properly support files and directories longer than 260 characters. This applies to Windows Explorer, `cmd.exe` and many other applications (including many IDEs as well as bash, perl and tcl that come with Git for Windows). + +# Opt-In configuration + +For this reason, long paths support in Git for Windows is disabled by default. + +That being said, long paths support for C-based git commands can be enabled by setting the `core.longpaths` option to true. Scripted git commands may still fail with this option, so use at your own risk. Example: + +```sh +git config core.longpaths true +``` + +# Technical background + +The root cause of the technical limitation of 260 chars lies deeply within the Win32 API. +Microsoft's online article [Naming Files, Paths, and Namespaces](http://msdn.microsoft.com/en-us/library/windows/desktop/aa365247(v=vs.85).aspx#maxpath) describes the reasons. +Git's source code itself does not have the limitation, it is Windows-only. + +# Implementation details + +Originally [introduced into Git for Windows 1.9.0](https://github.com/msysgit/git/pull/122), the idea to overcome the length limitation is to convert them into UNC paths (i.e. network paths of the form `\\?\...`). Such paths are accepted by many of the Win32 API's functions accepting UTF-16 strings (many functions in the Win32 API are available as ASCII and UTF-16 functions, marked by an `A` and a `W` suffix, respectively) and are allowed to have a length up to 32,767 wide characters. See e.g. [this commit](https://github.com/git-for-windows/git/commit/38b94fe15fb60e3871a166eec8cfd4265fee727f) for more details. From 5c3c4622ff5fa311fe6eccaa76d21e8f5dfda625 Mon Sep 17 00:00:00 2001 From: dscho Date: Sun, 16 Aug 2015 10:44:09 +0200 Subject: [PATCH 113/591] Link to the page I just created in the new wiki --- FAQ.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/FAQ.md b/FAQ.md index f62b0771e598e1..b1b957c93a68a2 100644 --- a/FAQ.md +++ b/FAQ.md @@ -17,4 +17,4 @@ There are several methods for working around these problems: * Install and use [ConEmu](http://conemu.github.io/). ## I get errors trying to check out files with long path names. -Windows file paths are by default limited to 255 characters. Some repositories may have committed files which contain paths longer than the limit. By default, *Git for Windows* does not support long paths, and will print errors when trying to perform any operation on a long file name. Set the configuration property core.longpaths to true to allow certain Git operations to properly handle these files. See [this wiki page](https://github.com/msysgit/msysgit/wiki/Git-cannot-create-a-file-or-directory-with-a-long-path) for more information. \ No newline at end of file +Windows file paths are by default limited to 255 characters. Some repositories may have committed files which contain paths longer than the limit. By default, *Git for Windows* does not support long paths, and will print errors when trying to perform any operation on a long file name. Set the configuration property `core.longpaths` to true to allow certain Git operations to properly handle these files. See [this wiki page](https://github.com/git-for-windows/git/wiki/Git-cannot-create-a-file-or-directory-with-a-long-path) for more information. \ No newline at end of file From 69d4842d6c487eea6b2d771f592ea6c992cf19fd Mon Sep 17 00:00:00 2001 From: glhez Date: Tue, 18 Aug 2015 21:05:45 +0200 Subject: [PATCH 114/591] Added two paragraph, one about $() syntax in PS1, and another about VIM complaining about CRLF. --- MSYS2-Notes.md | 39 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 39 insertions(+) diff --git a/MSYS2-Notes.md b/MSYS2-Notes.md index bf7ccfc7d7b25d..d594bc05f80575 100644 --- a/MSYS2-Notes.md +++ b/MSYS2-Notes.md @@ -4,6 +4,27 @@ Page for things that pop up while fiddling with MSys2. I had to replace `PS1="$PS1"'\n'` with `PS1="$PS1"$'\n'` within the `profile` file to get the git prompt working. See also [this msys2 ticket page](http://sourceforge.net/p/msys2/tickets/17/) +# PS1 Script (continuation) + +If you have this error (or something alike) with a prompt like this one: `\e[0;36m[\e[1;36m\t\e[0m\e[0;36m]\e[0m \e[0;33m\w\e[0m`**`$(__git_ps1 ' \e[0;31m(\e[1;31m%s\e[0m\e[0;31m)\e[0m')`**`\n$`, then you will have to replace the `$(...)` syntax by backtick (`). + +This PS1 will do the following error: +``` +[00:48:02] / +$ echo $PS1 +\e[0;36m[\e[1;36m\t\e[0m\e[0;36m]\e[0m \e[0;33m\w\e[0m$(__git_ps1 ' \e[0;31m(\e[1;31m%s\e[0m\e[0;31m)\e[0m')\n$ +bash: command substitution: line 1: syntax error near unexpected token `)' +bash: command substitution: line 1: `__git_ps1 ' (%s)')' +``` + +While this one won't: + +``` +$ export PS1="\\e[0;36m[\\e[1;36m\\t\\e[0m\\e[0;36m]\\e[0m \\e[0;33m\\w\\e[0m\`__git_ps1 ' \\e[0;31m(\\e[1;31m%s\\e[0m\\e[0;31m)\\e[0m'\`\\n\$ " +``` + +See [this stackoverflow question](http://stackoverflow.com/questions/21517281/ps1-command-substitution). + # Debugging the environment conversion to UTF-8 When trying to debug environment issues, it can be very helpful to print out the environment as it comes into Git. Unfortunately, `mingw_startup()` – which converts the environment to UTF-8 – is run so early that the `sprintf()` family of functions does not work: the locale has not been initialized yet (because this would require the environment, using the `LC_ALL` environment variable!). Therefore, something like this is required: @@ -39,4 +60,22 @@ Can be fixed with ``` chmod 600 ~/.ssh/* +``` + +# VIM + +VIM might complain about trailing character in the `_vimrc` file, such as: + +``` +line 3: +E488: Trailing characters: number^M +line 4: +E488: Trailing characters: nowrap^M +line 5: +``` + +This means the `_vimrc` have CRLF end line style instead of LF. You can either use a graphical tool such as Notepad++ or jEdit, or simply use dos2unix: + +``` +dos2unix $HOME/_vimrc ``` \ No newline at end of file From d506db75686aebe5ba9fd111eec2433088114f55 Mon Sep 17 00:00:00 2001 From: "www.google" Date: Wed, 19 Aug 2015 02:16:25 +0300 Subject: [PATCH 115/591] Updated How to participate (markdown) From 2c4918ee40285c0f0b5b6e8d5a9465bdb763fa02 Mon Sep 17 00:00:00 2001 From: Matthieu Vachon Date: Fri, 21 Aug 2015 11:31:02 -0400 Subject: [PATCH 116/591] Added instructions to install Git for Windows into an existing MSYS2 installation --- Install-inside-MSYS2-proper.md | 24 ++++++++++++++++++++++++ 1 file changed, 24 insertions(+) create mode 100644 Install-inside-MSYS2-proper.md diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md new file mode 100644 index 00000000000000..7e3ab5de6fd7ea --- /dev/null +++ b/Install-inside-MSYS2-proper.md @@ -0,0 +1,24 @@ +Git for Windows being based on `MSYS2`, it's possible to install the `git` package into an existing `MSYS2` installation. That means that if you are already using `MSYS2` on your computer, you can use Git for Windows without running the full installer or using the portable version. + +Note however that there is some caveats for going this way. Git for Windows created some patches for `msys2-runtime` that have not yet been sent upstream (this is planned, checkout out issue [#285](https://github.com/git-for-windows/git/issues/284) for current status). This means that you have to install Git for Windows customized `msys2-runtime` to have a fully working `git` inside `MSYS2`. + +Here the steps to take: + + 1. Open an `MSYS2` terminal. + 2. Edit `/etc/pacman.conf` and just before `[mingw32]` (line #71 on my machine), add the `git-for-windows` packages repository (Using `SigLevel = Optional TrustedOnly` because packages are not signed right now): + + [git-for-windows] + SigLevel = Optional TrustedOnly + Server = https://dl.bintray.com/git-for-windows/pacman/$arch + + 3. Then synchronize new repository + + pacman -Sy + + 4. And finally install correct packages + + pacman -S git-for-windows/msys2-runtime git-for-windows/mingw-w64-x86_64-git git-for-windows/mingw-w64-x86_64-git-doc-html git-for-windows/mingw-w64-x86_64-git-doc-man + + 5. Since you have updated `msys2-runtime`, you might get strange error messages right after finishing installation like an infinite stream of heap memory related messages. Don't panic, simply close all currently open shells and and program relying on `MSYS2` runtime. Once all close, start a new terminal again. + + 6. Finally, checkout that everything went well by doing `git --version` and it should output `git version 2.5.0.windows.1` \ No newline at end of file From faad9d142921efa98c098d576d7730ec3909ffe5 Mon Sep 17 00:00:00 2001 From: Matthieu Vachon Date: Fri, 21 Aug 2015 11:32:53 -0400 Subject: [PATCH 117/591] Fixed issue tyo --- Install-inside-MSYS2-proper.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index 7e3ab5de6fd7ea..8ddbe9d8bff01e 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -1,6 +1,6 @@ Git for Windows being based on `MSYS2`, it's possible to install the `git` package into an existing `MSYS2` installation. That means that if you are already using `MSYS2` on your computer, you can use Git for Windows without running the full installer or using the portable version. -Note however that there is some caveats for going this way. Git for Windows created some patches for `msys2-runtime` that have not yet been sent upstream (this is planned, checkout out issue [#285](https://github.com/git-for-windows/git/issues/284) for current status). This means that you have to install Git for Windows customized `msys2-runtime` to have a fully working `git` inside `MSYS2`. +Note however that there is some caveats for going this way. Git for Windows created some patches for `msys2-runtime` that have not yet been sent upstream (this is planned, checkout out issue [#284](https://github.com/git-for-windows/git/issues/284) for current status). This means that you have to install Git for Windows customized `msys2-runtime` to have a fully working `git` inside `MSYS2`. Here the steps to take: @@ -21,4 +21,4 @@ Here the steps to take: 5. Since you have updated `msys2-runtime`, you might get strange error messages right after finishing installation like an infinite stream of heap memory related messages. Don't panic, simply close all currently open shells and and program relying on `MSYS2` runtime. Once all close, start a new terminal again. - 6. Finally, checkout that everything went well by doing `git --version` and it should output `git version 2.5.0.windows.1` \ No newline at end of file + 6. Finally, checkout that everything went well by doing `git --version` and it should output something like `git version 2.5.0.windows.1` \ No newline at end of file From 73faa497a7f850daeb505e331c96cf521677b21b Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Mon, 24 Aug 2015 21:53:34 +0100 Subject: [PATCH 118/591] Responds to https://github.com/git-for-windows/git/issues/278#issuecomment-133204864 by providing /some/ documentation. --- Setting-your-Core.Editor-(e.g.-Notepad--).md | 35 ++++++++++++++++++++ 1 file changed, 35 insertions(+) create mode 100644 Setting-your-Core.Editor-(e.g.-Notepad--).md diff --git a/Setting-your-Core.Editor-(e.g.-Notepad--).md b/Setting-your-Core.Editor-(e.g.-Notepad--).md new file mode 100644 index 00000000000000..0cf6da9bfadac3 --- /dev/null +++ b/Setting-your-Core.Editor-(e.g.-Notepad--).md @@ -0,0 +1,35 @@ +Many Windows users are not familiar with vi/vim/emacs style command line terminal editors +[To quit: try `:q` to change out of text mode into command mode to allow the quit action]. + +Many users prefer their local Windows graphic editor, such as Notepad++, this note shows how. + +# Setting Notepad++ as your Core.Editor + +Notepad++ provides multiple useful options ([Npp](http://notepad-plus-plus.org) [wiki](http://docs/notepad-plus-lus.org/)). Install as required. + +The command + +`git config --global core.editor "'C:/Program Files/Notepad++/notepad++.exe' -multiInst -notabbar -nosession -noplugin`" + +should set up the following within your config file. + + + [core] + editor = 'C:/Program Files/Notepad++/notepad++.exe' -multiInst -notabbar -nosession -noplugin + + +Note that the windows executable path will probably need quoting to keep it as a single argument. You will need to adjust the path to match that of your OS version's programme files. + +The first three options make Notepad++ open a new, separate, simple window looking like a plain +vanilla Windows Notepad screen for each git editor call, with the right action when that +window is closed. + +Some users prefer not to use the '-notabbar', as it may become a preferred option if you didn't +have an Npp session already open, though the -nosession should prevent this. + +The canonical discussion is at [stackoverflow/1634161](http://stackoverflow.com/questions/1634161/how-do-i-use-notepad-or-other-with-msysgit) + +Note that in Git4Windows, with its MSYS2 underpinnings, we do pass paths that are +understandable by Npp, so there should be no need for any of the cygwin path mangling trickery discussed in the SO thread. + +#Other Editor Instructions - to be added here \ No newline at end of file From 3cd37b44048ee2d8c4c0b8e31c0b2797b042bb6b Mon Sep 17 00:00:00 2001 From: dscho Date: Wed, 26 Aug 2015 18:33:52 +0200 Subject: [PATCH 119/591] Start this long overdue page --- Symbolic-Links.md | 14 ++++++++++++++ 1 file changed, 14 insertions(+) create mode 100644 Symbolic-Links.md diff --git a/Symbolic-Links.md b/Symbolic-Links.md new file mode 100644 index 00000000000000..687fa4a9da52d7 --- /dev/null +++ b/Symbolic-Links.md @@ -0,0 +1,14 @@ +Starting with Windows Vista, there is support for symbolic links. These are not your grandfather's Unix symbolic links; They differ in quite a couple of ways: + +- Symbolic links are only available on Windows Vista and later, most notably not on XP +- You need the `SeCreateSymbolicLinkPrivilege` privilege +- Symbolic links pointing to remote filesystems are disabled by default (call `fsutil behavior query SymlinkEvaluation` to find out) +- Symbolic links will only work on NTFS, not on FAT +- Windows' symbolic links are typed: they need to know whether they point to a directory or to a file (for this reason, Git will update the type when it finds that it is wrong) +- Many programs do not understand symbolic links + +For those reasons, Git for Windows disables support for symbolic links by default (it will still read them when it encounters them). You can enable support via the `core.symlinks` config variable, e.g. when cloning: + +```sh +git clone -c core.symlinks=true +``` \ No newline at end of file From f5a13bf20c31531b9b0692d765f84a21ca502ebb Mon Sep 17 00:00:00 2001 From: David Macek Date: Thu, 27 Aug 2015 08:15:47 +0200 Subject: [PATCH 120/591] Noted defaul assignment and elevatation requirements for SeCreateSymbolicLinkPrivilege; see https://github.com/git-for-windows/git/issues/117#issuecomment-97262814 --- Symbolic-Links.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Symbolic-Links.md b/Symbolic-Links.md index 687fa4a9da52d7..0f1875297eb037 100644 --- a/Symbolic-Links.md +++ b/Symbolic-Links.md @@ -1,7 +1,7 @@ Starting with Windows Vista, there is support for symbolic links. These are not your grandfather's Unix symbolic links; They differ in quite a couple of ways: - Symbolic links are only available on Windows Vista and later, most notably not on XP -- You need the `SeCreateSymbolicLinkPrivilege` privilege +- You need the `SeCreateSymbolicLinkPrivilege` privilege (which is by default not assigned only to Administrators; also requires UAC elevation for any Administrators member, regardless of privilege assignment) - Symbolic links pointing to remote filesystems are disabled by default (call `fsutil behavior query SymlinkEvaluation` to find out) - Symbolic links will only work on NTFS, not on FAT - Windows' symbolic links are typed: they need to know whether they point to a directory or to a file (for this reason, Git will update the type when it finds that it is wrong) From 2d84556dba051f5669577c66edc636abfd02f6e0 Mon Sep 17 00:00:00 2001 From: David Macek Date: Thu, 27 Aug 2015 08:16:14 +0200 Subject: [PATCH 121/591] Updated Symbolic Links (markdown) --- Symbolic-Links.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Symbolic-Links.md b/Symbolic-Links.md index 0f1875297eb037..a0fc20b47d9efb 100644 --- a/Symbolic-Links.md +++ b/Symbolic-Links.md @@ -1,7 +1,7 @@ Starting with Windows Vista, there is support for symbolic links. These are not your grandfather's Unix symbolic links; They differ in quite a couple of ways: - Symbolic links are only available on Windows Vista and later, most notably not on XP -- You need the `SeCreateSymbolicLinkPrivilege` privilege (which is by default not assigned only to Administrators; also requires UAC elevation for any Administrators member, regardless of privilege assignment) +- You need the `SeCreateSymbolicLinkPrivilege` privilege (which is by default assigned only to Administrators; also requires UAC elevation for any Administrators member, regardless of privilege assignment) - Symbolic links pointing to remote filesystems are disabled by default (call `fsutil behavior query SymlinkEvaluation` to find out) - Symbolic links will only work on NTFS, not on FAT - Windows' symbolic links are typed: they need to know whether they point to a directory or to a file (for this reason, Git will update the type when it finds that it is wrong) From 75b6764584af0c384387002ab5fef2b68505db67 Mon Sep 17 00:00:00 2001 From: David Macek Date: Thu, 27 Aug 2015 08:20:28 +0200 Subject: [PATCH 122/591] Corrected statement about remote symlinks; see https://github.com/git-for-windows/git/issues/117#issuecomment-99161881 --- Symbolic-Links.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Symbolic-Links.md b/Symbolic-Links.md index a0fc20b47d9efb..2e568e0eedc42b 100644 --- a/Symbolic-Links.md +++ b/Symbolic-Links.md @@ -2,7 +2,7 @@ Starting with Windows Vista, there is support for symbolic links. These are not - Symbolic links are only available on Windows Vista and later, most notably not on XP - You need the `SeCreateSymbolicLinkPrivilege` privilege (which is by default assigned only to Administrators; also requires UAC elevation for any Administrators member, regardless of privilege assignment) -- Symbolic links pointing to remote filesystems are disabled by default (call `fsutil behavior query SymlinkEvaluation` to find out) +- Symbolic links on remote filesystems are disabled by default (call `fsutil behavior query SymlinkEvaluation` to find out) - Symbolic links will only work on NTFS, not on FAT - Windows' symbolic links are typed: they need to know whether they point to a directory or to a file (for this reason, Git will update the type when it finds that it is wrong) - Many programs do not understand symbolic links From 5ae4a952bceca9cf5b6735be307aecf53e12347a Mon Sep 17 00:00:00 2001 From: David Allsopp Date: Sun, 30 Aug 2015 13:49:57 +0100 Subject: [PATCH 123/591] Updated Symbolic Links (markdown) --- Symbolic-Links.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Symbolic-Links.md b/Symbolic-Links.md index 2e568e0eedc42b..85d5c911b41984 100644 --- a/Symbolic-Links.md +++ b/Symbolic-Links.md @@ -1,7 +1,7 @@ Starting with Windows Vista, there is support for symbolic links. These are not your grandfather's Unix symbolic links; They differ in quite a couple of ways: - Symbolic links are only available on Windows Vista and later, most notably not on XP -- You need the `SeCreateSymbolicLinkPrivilege` privilege (which is by default assigned only to Administrators; also requires UAC elevation for any Administrators member, regardless of privilege assignment) +- You need the `SeCreateSymbolicLinkPrivilege` privilege, which is by default assigned only to Administrators but can be assigned to normal users using Local Security Policy (or via Active Directory). Home Editions of Windows Vista and Windows 7 do not have Local Security Policy, but the freely available Polsedit (http://www.southsoftware.com) can be used on these editions. Note that regardless of privilege assignment, members of the Administrators group will also require UAC elevation (see the full details in *Access Token Changes* just above https://msdn.microsoft.com/en-us/library/bb530410.aspx#vistauac_topic4) - Symbolic links on remote filesystems are disabled by default (call `fsutil behavior query SymlinkEvaluation` to find out) - Symbolic links will only work on NTFS, not on FAT - Windows' symbolic links are typed: they need to know whether they point to a directory or to a file (for this reason, Git will update the type when it finds that it is wrong) From 1f3f96205b65206c386a3126aaa003f433ad98cc Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Thu, 3 Sep 2015 10:27:51 +0200 Subject: [PATCH 124/591] Illustrate an alternative to installing the full Git SDK --- Vagrant.md | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/Vagrant.md b/Vagrant.md index 8940a93d730349..f28c12478c672c 100644 --- a/Vagrant.md +++ b/Vagrant.md @@ -16,6 +16,12 @@ Note that the prompt shows that the current directory in the ssh session inside To compile and install Git, you will have to run `make clean` first because *Git* will have built *Windows* binaries in the same directory (when we will need *Linux* binaries inside the virtual machine started by Vagrant). After calling `make install` and `export PATH=$HOME/bin:$PATH` you will be able to run the Git version built from the source files in `/vagrant/git/`. +# Alternative to the Git SDK way + +If you cannot download and install the Git SDK for some reason or other, you could also clone [the Git source code](https://github.com/git-for-windows/git) using [Git for Windows](https://git-for-windows.github.io/) instead. If Git for Windows does not even work for you, you could even download the source code [as a `.zip`](https://github.com/git-for-windows/git/archive/master.zip) and unpack it. + +After that, continue with the `vagrant up` step above. + # Why? Git was born on Linux. Over the years, it has become more and more platform-independent, but still support for Linux outshines support for every other platform, including Windows. Therefore it is preferable under certain circumstances to run Git inside Linux in a virtual machine, for example From 393a685f536637f8b30de018643dc5edf96370d9 Mon Sep 17 00:00:00 2001 From: Pete Bachant Date: Tue, 8 Sep 2015 10:57:41 -0400 Subject: [PATCH 125/591] Remove strange character --- Building-msys2-runtime.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Building-msys2-runtime.md b/Building-msys2-runtime.md index a09e2e15556788..d0dd74f0e54591 100644 --- a/Building-msys2-runtime.md +++ b/Building-msys2-runtime.md @@ -2,7 +2,7 @@ 1. Just run the [SDK installer](https://git-for-windows.github.io/#download-sdk). -# Build `msys2-⁠runtime` +# Build `msys2-runtime` 1. Open the *Git for Windows SDK* *MSys* shell by double clicking `msys2_shell.bat` in the install folder. (i.e. not the *MinGW 32-bit* nor the *MinGW 64-bit* one). From a4f13976dce669a9f5590429dd4624b0231747b7 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Wed, 9 Sep 2015 18:05:55 +0200 Subject: [PATCH 126/591] Mention that `base-devel` and `binutils` are required before building MSys packages --- Package-management.md | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/Package-management.md b/Package-management.md index 8281d7f01edccd..ccba4312b88315 100644 --- a/Package-management.md +++ b/Package-management.md @@ -82,6 +82,12 @@ To build MSys packages, you need to start the `MSys` shell (which sets `MSYSTEM= makepkg -s ``` +*Note*: Before building the first MSys package, you need to install the base packages for development: + +```sh +pacman -Sy base-devel binutils +``` + ### Build packages from locally-patched sources When testing Pull Requests or debugging certain issues, it is convenient to build packages from source code other than the canonical one listed in the `PKGBUILD` file. This can be achieved by switching to the subdirectory of `/usr/src/MINGW-packages` or `/usr/src/MSYS2-packages`, respectively, corresponding to the package you want to build, ensure that the `src/` directory is populated (and call `makepkg-mingw --nobuild -s` or `makepkg --nobuild -s` otherwise), then patch the source code in the `src/` subdirectory and after that call From 6749d206c5ff6fc4f9265a8289c37fdb9759efad Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Thu, 10 Sep 2015 08:31:34 +0200 Subject: [PATCH 127/591] Lay it out to laypeople how to fix the DLL ranges manually, even if they probably are in way over their heads ;-) --- 32-bit-issues.md | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) diff --git a/32-bit-issues.md b/32-bit-issues.md index 675bdba59cb768..cd1b2a02ea4955 100644 --- a/32-bit-issues.md +++ b/32-bit-issues.md @@ -46,4 +46,15 @@ If you cannot switch to 64-bit for any reason, reinstalling Git for Windows will To fix the problem of address range overlaps, MSys2 offers a utility called `rebase.exe` (which confusingly has nothing at all to do with `git rebase`) to adjust the address range of a given set of `.dll` files. -Unfortunately the [symptom](#the-symptom-of-an-address-range-that-needs-adjusting) occurs not all that rarely, therefore there is even a script to make `rebase.exe` more convenient to use: `/usr/bin/rebaseall`. This script is meant to be executed via Dash instead of Bash, to avoid chicken-and-egg problems with Bash not being able to run properly unless the address range is already fixed. Typically it is unnecessary to run this script manually because it is run as part of Git for Windows' installation process. If the [symptom](#the-symptom-of-an-address-range-that-needs-adjusting) occurs at some stage long after Git for Windows was installed, reinstalling Git for Windows is the most convenient way to fix it. \ No newline at end of file +Unfortunately the [symptom](#the-symptom-of-an-address-range-that-needs-adjusting) occurs not all that rarely, therefore there is even a script to make `rebase.exe` more convenient to use: `/usr/bin/rebaseall`. This script is meant to be executed via Dash instead of Bash, to avoid chicken-and-egg problems with Bash not being able to run properly unless the address range is already fixed. Typically it is unnecessary to run this script manually because it is run as part of Git for Windows' installation process. If the [symptom](#the-symptom-of-an-address-range-that-needs-adjusting) occurs at some stage long after Git for Windows was installed, reinstalling Git for Windows is the most convenient way to fix it. + +If you still insist on fixing it manually, please understand that this is *not* recommended without knowledge of MSys2 internals (read: if you get stuck, please do not open a ticket to learn more about MSys2; use the recommended way instead: reinstall Git for Windows). The manual way goes like this: + +1. close each and every `mintty` window +2. terminate each and every Bash +3. terminate even background processes that use the MSys2 runtime, such as `ssh-agent` +4. open `cmd.exe`, change the directory to Git's top-level one and then run + + ```cmd + usr\bin\dash -c '/usr/bin/dash /usr/bin/rebaseall -p' + ``` \ No newline at end of file From 983533717caa429a207f34c16185e19397bb9fd8 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Mon, 14 Sep 2015 12:02:09 +0200 Subject: [PATCH 128/591] It is not only binutils, but msys2-devel that you need before building MSys2 packages --- Package-management.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/Package-management.md b/Package-management.md index ccba4312b88315..5594d1aea5ff73 100644 --- a/Package-management.md +++ b/Package-management.md @@ -82,10 +82,10 @@ To build MSys packages, you need to start the `MSys` shell (which sets `MSYSTEM= makepkg -s ``` -*Note*: Before building the first MSys package, you need to install the base packages for development: +*Note*: Before building the first MSys package, as per [MSys2's own documentation](http://sourceforge.net/p/msys2/wiki/Contributing%20to%20MSYS2/) you need to install the development packages for development: ```sh -pacman -Sy base-devel binutils +pacman -Sy base-devel msys2-devel ``` ### Build packages from locally-patched sources From 9808ee13d2b8d3af3eebbb7dff149e265ba215b5 Mon Sep 17 00:00:00 2001 From: tkoeller Date: Wed, 16 Sep 2015 18:21:01 +0200 Subject: [PATCH 129/591] Described Windows domain authentication. --- FAQ.md | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/FAQ.md b/FAQ.md index b1b957c93a68a2..8c529babbd14e6 100644 --- a/FAQ.md +++ b/FAQ.md @@ -17,4 +17,10 @@ There are several methods for working around these problems: * Install and use [ConEmu](http://conemu.github.io/). ## I get errors trying to check out files with long path names. -Windows file paths are by default limited to 255 characters. Some repositories may have committed files which contain paths longer than the limit. By default, *Git for Windows* does not support long paths, and will print errors when trying to perform any operation on a long file name. Set the configuration property `core.longpaths` to true to allow certain Git operations to properly handle these files. See [this wiki page](https://github.com/git-for-windows/git/wiki/Git-cannot-create-a-file-or-directory-with-a-long-path) for more information. \ No newline at end of file +Windows file paths are by default limited to 255 characters. Some repositories may have committed files which contain paths longer than the limit. By default, *Git for Windows* does not support long paths, and will print errors when trying to perform any operation on a long file name. Set the configuration property `core.longpaths` to true to allow certain Git operations to properly handle these files. See [this wiki page](https://github.com/git-for-windows/git/wiki/Git-cannot-create-a-file-or-directory-with-a-long-path) for more information. + +## How do I access a repository hosted on a Microsoft Team Foundation Server inside a Windows domain? + +The Microsoft Team Foundation Server is capable of hosting git repositories. If the server is a member of a windows domain, and your user account is in that domain, you can use domain authentication to identify yourself to the server, and can access git repositories without having to enter any credentials. For this to work, the server has to be configured to use domain authentication, not NTLM authentication. The repository URL can be obtained from the TFS web interface, it may look like http://server.example.com:8080/tfs/TWA/TeamDev/_git/reponame. + +In order to instruct git to use domain authentication, prefix the server name with ':@', like so: http://:@server.example.com:8080/tfs/TWA/TeamDev/_git/reponame. This is a special case of the usual username:password@server' syntax, where bot the 'username' and 'password' fields are empty. This causes git to look up and use your domain credentials. From 3c9c5abc481d7dfb7ec402fb55faab61de4a71ae Mon Sep 17 00:00:00 2001 From: Matthieu Vachon Date: Wed, 16 Sep 2015 12:38:41 -0400 Subject: [PATCH 130/591] Changed formatting a bit for Microsoft Team Foundation Server question --- FAQ.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/FAQ.md b/FAQ.md index 8c529babbd14e6..28fac2626b779f 100644 --- a/FAQ.md +++ b/FAQ.md @@ -23,4 +23,4 @@ Windows file paths are by default limited to 255 characters. Some repositories m The Microsoft Team Foundation Server is capable of hosting git repositories. If the server is a member of a windows domain, and your user account is in that domain, you can use domain authentication to identify yourself to the server, and can access git repositories without having to enter any credentials. For this to work, the server has to be configured to use domain authentication, not NTLM authentication. The repository URL can be obtained from the TFS web interface, it may look like http://server.example.com:8080/tfs/TWA/TeamDev/_git/reponame. -In order to instruct git to use domain authentication, prefix the server name with ':@', like so: http://:@server.example.com:8080/tfs/TWA/TeamDev/_git/reponame. This is a special case of the usual username:password@server' syntax, where bot the 'username' and 'password' fields are empty. This causes git to look up and use your domain credentials. +In order to instruct git to use domain authentication, prefix the server name with `:@`, like so: `http://:@server.example.com:8080/tfs/TWA/TeamDev/_git/reponame`. This is a special case of the usual `username:password@server` syntax, where bot the `username` and `password` fields are empty. This causes git to look up and use your domain credentials. From 77a750fcd1cdb1aa8cb20da7c0d2e5510765ccee Mon Sep 17 00:00:00 2001 From: Vincent De Smet Date: Thu, 17 Sep 2015 15:27:31 +0700 Subject: [PATCH 131/591] added info about package manager and updates --- FAQ.md | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/FAQ.md b/FAQ.md index 28fac2626b779f..a31d0152e839ba 100644 --- a/FAQ.md +++ b/FAQ.md @@ -2,6 +2,12 @@ *Git for Windows* used to be developed using the development environment called "msysGit", but roughly coinciding with Git 2.1, msysGit was superseded by a new development environment: the [Git for Windows SDK](https://github.com/git-for-windows/build-extra/releases). +## How do I update *Git for Windows* upon new releases? + +This depends on how you installed *Git for Windows*. The bundle installation requires you to download and install the new version. Any customizations you made will be kept as long as you did so in the appropriate configuration folders. + +For advanced users working with the *Git for Windows* SDK `pacman` is available as a package manager. See [Package management](Package-management) + ## Some native console programs don't work when run from Git Bash. How to fix it? From 0f2668d968bd10c7f7ed89854b0687ddf213a69d Mon Sep 17 00:00:00 2001 From: tkoeller Date: Thu, 17 Sep 2015 12:07:41 +0200 Subject: [PATCH 132/591] Minor changes, fixed typo --- FAQ.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/FAQ.md b/FAQ.md index a31d0152e839ba..d32a4111974a56 100644 --- a/FAQ.md +++ b/FAQ.md @@ -27,6 +27,6 @@ Windows file paths are by default limited to 255 characters. Some repositories m ## How do I access a repository hosted on a Microsoft Team Foundation Server inside a Windows domain? -The Microsoft Team Foundation Server is capable of hosting git repositories. If the server is a member of a windows domain, and your user account is in that domain, you can use domain authentication to identify yourself to the server, and can access git repositories without having to enter any credentials. For this to work, the server has to be configured to use domain authentication, not NTLM authentication. The repository URL can be obtained from the TFS web interface, it may look like http://server.example.com:8080/tfs/TWA/TeamDev/_git/reponame. +The Microsoft Team Foundation Server is capable of hosting git repositories. If the server is a member of a windows domain, and your user account is in that domain, you can use domain authentication to identify yourself to the server, and can thus access git repositories without having to enter any credentials. For this to work, the server has to be configured to use domain authentication, _not_ NTLM authentication. The repository URL can be obtained from the TFS web interface, it may look like http://server.example.com:8080/tfs/TWA/TeamDev/_git/reponame. -In order to instruct git to use domain authentication, prefix the server name with `:@`, like so: `http://:@server.example.com:8080/tfs/TWA/TeamDev/_git/reponame`. This is a special case of the usual `username:password@server` syntax, where bot the `username` and `password` fields are empty. This causes git to look up and use your domain credentials. +In order to instruct git to use domain authentication, prefix the server name with `:@`, like so: `http://:@server.example.com:8080/tfs/TWA/TeamDev/_git/reponame`. This is a special case of the usual `username:password@server` syntax, where both the `username` and `password` fields are empty. This causes git to look up and use your domain credentials. From 09fdb2d6b1e02b00d387ded08edf55dad0e9495e Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Sun, 20 Sep 2015 15:18:11 +0100 Subject: [PATCH 133/591] Create an initial page directly from dscho's notes. Clarifications for lesser mortals can be added later (especially the catch-22 of knowing " if this wants to update the msys2-runtime...") --- Updating-your-SDK.md | 61 ++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 61 insertions(+) create mode 100644 Updating-your-SDK.md diff --git a/Updating-your-SDK.md b/Updating-your-SDK.md new file mode 100644 index 00000000000000..662061e9b66af2 --- /dev/null +++ b/Updating-your-SDK.md @@ -0,0 +1,61 @@ +Extract from the [Releases page](https://github.com/git-for-windows/build-extra/releases)[the segment about net-installer 1.0.0-rc-1]. Note the Caution parts! + +# The SDK 'net installer' + +The SDK 'net installer' is a self-extracting archive containing a minimal +set of files needed to bootstrap an entire development environment to +compile and run Git for Windows. + +When run as executable, it automatically runs `setup-git-sdk.bat` after +extracting the files. Users who prefer to unpack the archive manually +with 7-Zip need to run that batch file manually, too. + +The files contained in the net installer are parts of MSys2's +'msys2-runtime', 'pacman' and 'gnupg' packages, carefully selected to +keep the size of the installer small yet still allowing to use the +Pacman package manager to initialize a full-fledged MSys2 environment +plus Git for Windows' packages. + +The bootstrap script needs to force-install the packages because the net +installer comes without any package information and Pacman would +therefore refuse to overwrite the files from above-mentioned packages. + +# To keep the development environment up-to-date + +To keep the development environment up-to-date, developers need to run + + pacman -Syu + +from time to time. + +### Caution + +There is one caveat, though: if this wants to update the msys2-runtime +itself, it is *highly* recommended to close all other MSys2 programs +(e.g. terminal windows, Bash sessions, etc) and update msys2-runtime +individually, immediately close the window (i.e. *not* run `exit`) and +then restart the update in a new window. + +The reason: pacman itself is linked to the msys2-runtime, and updating +the runtime "in flight" results most often in heap corruption as far as +MSys2 is concerned. For the same reason, updates to Bash and Pacman +itself should be handled in the same manner. + +## Alternative Method + +An alternative method is to start `git-cmd.exe` and run `pacman -Sy +` for `msys2-runtime`, `bash` and `pacman` as needed, because +that ensures that no obsolete binary continues to be used after the +update. + +## Origin of 'net installer' concept + +The idea for the 'net installer' originated in the Git for Windows +project when it was still based on MSys 1.x. At that time, MSys 1.x did +not have a package manager, therefore the original net installer +(ab-)used Git as a package manager. + +Since the new net installer no longer needs to ship with Git (instead +using Pacman to install the mingw-w64-git package that is current at the +time the net installer is launched), its versions are no longer tightly +coupled to the Git version. \ No newline at end of file From 029982cb7555b87cda3be86c373b6364fdc7b813 Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Sun, 20 Sep 2015 21:36:23 +0100 Subject: [PATCH 134/591] Extra links to the G4W package management page and the ArchLinux pages --- Updating-your-SDK.md | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/Updating-your-SDK.md b/Updating-your-SDK.md index 662061e9b66af2..e9b0e7f7b14d20 100644 --- a/Updating-your-SDK.md +++ b/Updating-your-SDK.md @@ -48,6 +48,14 @@ An alternative method is to start `git-cmd.exe` and run `pacman -Sy that ensures that no obsolete binary continues to be used after the update. +### See Also: + +* [G4W Package Management](https://github.com/git-for-windows/git/wiki/Package-management) +* [pacman man page](https://www.archlinux.org/pacman/pacman.8.html) +* [PKGBuild man page](https://www.archlinux.org/pacman/PKGBUILD.5.html) +* [makepkg man page](https://www.archlinux.org/pacman/makepkg.8.html) +* ArchLinux articles - [Creating Packages](https://wiki.archlinux.org/index.php/Creating_packages) and [PKGBuild](https://wiki.archlinux.org/index.php/PKGBUILD) + ## Origin of 'net installer' concept The idea for the 'net installer' originated in the Git for Windows From 2adbabde229e46ae8b96e21e58da8ec19ff3e250 Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Sun, 20 Sep 2015 21:38:53 +0100 Subject: [PATCH 135/591] Added Msys2 links to complete the initial set of links. --- Updating-your-SDK.md | 1 + 1 file changed, 1 insertion(+) diff --git a/Updating-your-SDK.md b/Updating-your-SDK.md index e9b0e7f7b14d20..2a68ba0fb5ffd2 100644 --- a/Updating-your-SDK.md +++ b/Updating-your-SDK.md @@ -55,6 +55,7 @@ update. * [PKGBuild man page](https://www.archlinux.org/pacman/PKGBUILD.5.html) * [makepkg man page](https://www.archlinux.org/pacman/makepkg.8.html) * ArchLinux articles - [Creating Packages](https://wiki.archlinux.org/index.php/Creating_packages) and [PKGBuild](https://wiki.archlinux.org/index.php/PKGBUILD) +* [MSYS2 Introduction & Contributing](http://sourceforge.net/p/msys2/wiki/Contributing%20to%20MSYS2/) ## Origin of 'net installer' concept From 7611635eb8b7ff44e19ab42c451a30ef7cc9675d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=EB=A7=88=EB=88=84=EC=97=98?= Date: Mon, 21 Sep 2015 16:58:27 +0200 Subject: [PATCH 136/591] Added call to update-core --- Updating-your-SDK.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/Updating-your-SDK.md b/Updating-your-SDK.md index 2a68ba0fb5ffd2..66b5e59f94b415 100644 --- a/Updating-your-SDK.md +++ b/Updating-your-SDK.md @@ -24,6 +24,8 @@ therefore refuse to overwrite the files from above-mentioned packages. To keep the development environment up-to-date, developers need to run + update-core + # If one of the packages is updated during update-core you *MUST* restart MSys2 pacman -Syu from time to time. From e617133d627b87d939bffd6cc4ccbea3f6bf90a0 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=EB=A7=88=EB=88=84=EC=97=98?= Date: Mon, 21 Sep 2015 17:06:08 +0200 Subject: [PATCH 137/591] clarified update-core call --- Updating-your-SDK.md | 18 ++++++------------ 1 file changed, 6 insertions(+), 12 deletions(-) diff --git a/Updating-your-SDK.md b/Updating-your-SDK.md index 66b5e59f94b415..e62f32efca6808 100644 --- a/Updating-your-SDK.md +++ b/Updating-your-SDK.md @@ -25,23 +25,17 @@ therefore refuse to overwrite the files from above-mentioned packages. To keep the development environment up-to-date, developers need to run update-core - # If one of the packages is updated during update-core you *MUST* restart MSys2 + # If core-packages are updated during that call you MUST restart MSys2 pacman -Syu from time to time. -### Caution +### Caution (update-core) -There is one caveat, though: if this wants to update the msys2-runtime -itself, it is *highly* recommended to close all other MSys2 programs -(e.g. terminal windows, Bash sessions, etc) and update msys2-runtime -individually, immediately close the window (i.e. *not* run `exit`) and -then restart the update in a new window. - -The reason: pacman itself is linked to the msys2-runtime, and updating -the runtime "in flight" results most often in heap corruption as far as -MSys2 is concerned. For the same reason, updates to Bash and Pacman -itself should be handled in the same manner. +Core packages like the `msys2-runtime`, `bash` or `pacman` itself should be updated +via the `update-core` script. Because those core packages are linked to the +`msys2-runtime` (and each other), and updating the runtime "in flight" results most +often in heap corruption as far as MSys2 is concerned. ## Alternative Method From f59a1e76f092bf761241a4e7c92773d36e014a8f Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Mon, 21 Sep 2015 20:31:46 +0100 Subject: [PATCH 138/591] added link to the setup-git-sdk.bat and noted that it offers comments which illuminate what is going on. --- Updating-your-SDK.md | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/Updating-your-SDK.md b/Updating-your-SDK.md index e62f32efca6808..46e1a97135d37a 100644 --- a/Updating-your-SDK.md +++ b/Updating-your-SDK.md @@ -8,7 +8,9 @@ compile and run Git for Windows. When run as executable, it automatically runs `setup-git-sdk.bat` after extracting the files. Users who prefer to unpack the archive manually -with 7-Zip need to run that batch file manually, too. +with 7-Zip need to run that batch file manually, too. The script is +extensively commented to assist in understanding the installation process +and issues. The files contained in the net installer are parts of MSys2's 'msys2-runtime', 'pacman' and 'gnupg' packages, carefully selected to @@ -52,6 +54,7 @@ update. * [makepkg man page](https://www.archlinux.org/pacman/makepkg.8.html) * ArchLinux articles - [Creating Packages](https://wiki.archlinux.org/index.php/Creating_packages) and [PKGBuild](https://wiki.archlinux.org/index.php/PKGBUILD) * [MSYS2 Introduction & Contributing](http://sourceforge.net/p/msys2/wiki/Contributing%20to%20MSYS2/) +* [SDK's setup-git-sdk.bat script](https://github.com/git-for-windows/build-extra/blob/master/sdk-installer/setup-git-sdk.bat) ## Origin of 'net installer' concept From 6edf41e24afb4e129e98005fe4b7a7a4ef19555b Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Mon, 21 Sep 2015 21:25:20 +0100 Subject: [PATCH 139/591] added link to the core-update script source --- Updating-your-SDK.md | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/Updating-your-SDK.md b/Updating-your-SDK.md index 46e1a97135d37a..b321d9dbe0a94e 100644 --- a/Updating-your-SDK.md +++ b/Updating-your-SDK.md @@ -35,7 +35,7 @@ from time to time. ### Caution (update-core) Core packages like the `msys2-runtime`, `bash` or `pacman` itself should be updated -via the `update-core` script. Because those core packages are linked to the +via the pacman `update-core` script. Because those core packages are linked to the `msys2-runtime` (and each other), and updating the runtime "in flight" results most often in heap corruption as far as MSys2 is concerned. @@ -55,6 +55,7 @@ update. * ArchLinux articles - [Creating Packages](https://wiki.archlinux.org/index.php/Creating_packages) and [PKGBuild](https://wiki.archlinux.org/index.php/PKGBUILD) * [MSYS2 Introduction & Contributing](http://sourceforge.net/p/msys2/wiki/Contributing%20to%20MSYS2/) * [SDK's setup-git-sdk.bat script](https://github.com/git-for-windows/build-extra/blob/master/sdk-installer/setup-git-sdk.bat) +* [pacman's core-update script](https://github.com/Alexpux/MSYS2-pacman/blob/master/scripts/update-core.sh.in) ## Origin of 'net installer' concept From 23ed34fba1586d390123544e0765950e9e40a2f3 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Wed, 23 Sep 2015 22:38:49 +0200 Subject: [PATCH 140/591] Link directly to the first release candidate --- Updating-your-SDK.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Updating-your-SDK.md b/Updating-your-SDK.md index b321d9dbe0a94e..d4cc01429a9dec 100644 --- a/Updating-your-SDK.md +++ b/Updating-your-SDK.md @@ -1,4 +1,4 @@ -Extract from the [Releases page](https://github.com/git-for-windows/build-extra/releases)[the segment about net-installer 1.0.0-rc-1]. Note the Caution parts! +Extract from the [Git for Windows SDK release page](https://github.com/git-for-windows/build-extra/releases/tag/net-installer-1.0.0-rc-1). Note the Caution parts! # The SDK 'net installer' From aca099c5d700307f196e8b929d8f2bafe400221c Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Wed, 23 Sep 2015 22:43:30 +0200 Subject: [PATCH 141/591] Link to the setup-git-sdk script --- Updating-your-SDK.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Updating-your-SDK.md b/Updating-your-SDK.md index d4cc01429a9dec..72babbbfe5df22 100644 --- a/Updating-your-SDK.md +++ b/Updating-your-SDK.md @@ -6,7 +6,7 @@ The SDK 'net installer' is a self-extracting archive containing a minimal set of files needed to bootstrap an entire development environment to compile and run Git for Windows. -When run as executable, it automatically runs `setup-git-sdk.bat` after +When run as executable, it automatically runs [`setup-git-sdk.bat`](https://github.com/git-for-windows/build-extra/blob/master/sdk-installer/setup-git-sdk.bat) after extracting the files. Users who prefer to unpack the archive manually with 7-Zip need to run that batch file manually, too. The script is extensively commented to assist in understanding the installation process From 1dfa2265b50afeff352517b2fdb60988b228e098 Mon Sep 17 00:00:00 2001 From: Gregory Pakosz Date: Wed, 23 Sep 2015 22:47:57 +0200 Subject: [PATCH 142/591] removed Unicode word joiners (U+2060) --- Building-msys2-runtime.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/Building-msys2-runtime.md b/Building-msys2-runtime.md index d0dd74f0e54591..2958f6f65fdd8c 100644 --- a/Building-msys2-runtime.md +++ b/Building-msys2-runtime.md @@ -6,13 +6,13 @@ 1. Open the *Git for Windows SDK* *MSys* shell by double clicking `msys2_shell.bat` in the install folder. (i.e. not the *MinGW 32-bit* nor the *MinGW 64-bit* one). -2. Install the MSys2 Toolchain: `pacman -⁠S base-devel`. +2. Install the MSys2 Toolchain: `pacman -S base-devel`. 3. Initialize the local MSYS2-packages clone: `cd /usr/src/MSYS2-packages && git fetch origin && git checkout master`. 4. Change to the `msys2-runtime` directory: `cd msys2-runtime` -5. Build the package: `makepkg -⁠s`. +5. Build the package: `makepkg -s`. # Rebuild the msys2-runtime From d573090c71868be4c23cddd4464aff39b33aa869 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Wed, 23 Sep 2015 22:59:23 +0200 Subject: [PATCH 143/591] Spell out the commands of the alternative method --- Updating-your-SDK.md | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/Updating-your-SDK.md b/Updating-your-SDK.md index 72babbbfe5df22..be5e5478a71057 100644 --- a/Updating-your-SDK.md +++ b/Updating-your-SDK.md @@ -41,9 +41,7 @@ often in heap corruption as far as MSys2 is concerned. ## Alternative Method -An alternative method is to start `git-cmd.exe` and run `pacman -Sy -` for `msys2-runtime`, `bash` and `pacman` as needed, because -that ensures that no obsolete binary continues to be used after the +An alternative method is to start `git-cmd.exe` and run `pacman -Sy --needed msys2-runtime` and `pacman -S --needed pacman bash`, because that ensures that no obsolete binary continues to be used after the update. ### See Also: From 683c4b766290884ad5fe53490fcede88b3d70ab8 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Wed, 23 Sep 2015 23:01:40 +0200 Subject: [PATCH 144/591] Clarify that the idea is to install *everything* via packages --- Updating-your-SDK.md | 5 +---- 1 file changed, 1 insertion(+), 4 deletions(-) diff --git a/Updating-your-SDK.md b/Updating-your-SDK.md index be5e5478a71057..d9f9a58592ac87 100644 --- a/Updating-your-SDK.md +++ b/Updating-your-SDK.md @@ -62,7 +62,4 @@ project when it was still based on MSys 1.x. At that time, MSys 1.x did not have a package manager, therefore the original net installer (ab-)used Git as a package manager. -Since the new net installer no longer needs to ship with Git (instead -using Pacman to install the mingw-w64-git package that is current at the -time the net installer is launched), its versions are no longer tightly -coupled to the Git version. \ No newline at end of file +Since the new net installer no longer needs to ship with Git (instead using Pacman to install all the packages (including the `mingw-w64-git` package) that are current at the time the net installer is launched), its versions are no longer tightly coupled to the Git version. \ No newline at end of file From 39831351f0c3fbc3f86dfa61312960abcbd192e5 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Thu, 24 Sep 2015 16:49:11 +0200 Subject: [PATCH 145/591] Add the valuable hint that Git's source code needs to be checked out with Unix line endings to be compiled inside Vagrant --- Vagrant.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Vagrant.md b/Vagrant.md index f28c12478c672c..1967e067938ab9 100644 --- a/Vagrant.md +++ b/Vagrant.md @@ -18,7 +18,7 @@ To compile and install Git, you will have to run `make clean` first because *Git # Alternative to the Git SDK way -If you cannot download and install the Git SDK for some reason or other, you could also clone [the Git source code](https://github.com/git-for-windows/git) using [Git for Windows](https://git-for-windows.github.io/) instead. If Git for Windows does not even work for you, you could even download the source code [as a `.zip`](https://github.com/git-for-windows/git/archive/master.zip) and unpack it. +If you cannot download and install the Git SDK for some reason or other, you could also clone [the Git source code](https://github.com/git-for-windows/git) using [Git for Windows](https://git-for-windows.github.io/) instead, but make sure that Unix line endings are used: `git clone -c core.autocrlf=false https://github.com/git-for-windows/git vagrant-git`. If Git for Windows does not even work for you, you could also download the source code [as a `.zip`](https://github.com/git-for-windows/git/archive/master.zip) and unpack it. After that, continue with the `vagrant up` step above. From bbb1961b42c53e1f7dff7c75d5797f1605794ffd Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Sat, 26 Sep 2015 15:52:33 +0200 Subject: [PATCH 146/591] Clarify what the sign-off is about --- Good-commits.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Good-commits.md b/Good-commits.md index 956e700c3df396..75ee091f653664 100644 --- a/Good-commits.md +++ b/Good-commits.md @@ -17,7 +17,7 @@ If you tried several strategies to solve your problem, you will want to describe Also important: - The commit message should always start with a single, short line summarizing the change. -- [Sign off](https://github.com/git/git/blob/v2.5.0/Documentation/SubmittingPatches#L234-L286) on your change. +- [Sign off](https://github.com/git/git/blob/v2.5.0/Documentation/SubmittingPatches#L234-L286) on your change (i.e. state that you release this patch as Open Source, if applicable with your employer's consent). - Format the commit message to wrap at 76 columns per line. A good example for a commit message is [git-for-windows/build-extra@a64fe115](github.com/git-for-windows/build-extra/commit/a64fe115d901cab775c881bd1624218ac28de4d4): From 5550dc33a07acab32ed9c621d26891a9b1dbecfa Mon Sep 17 00:00:00 2001 From: mojocorp Date: Mon, 5 Oct 2015 22:35:22 +0200 Subject: [PATCH 147/591] Updated FAQ (markdown) --- FAQ.md | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/FAQ.md b/FAQ.md index d32a4111974a56..a45db9e53c7e59 100644 --- a/FAQ.md +++ b/FAQ.md @@ -30,3 +30,7 @@ Windows file paths are by default limited to 255 characters. Some repositories m The Microsoft Team Foundation Server is capable of hosting git repositories. If the server is a member of a windows domain, and your user account is in that domain, you can use domain authentication to identify yourself to the server, and can thus access git repositories without having to enter any credentials. For this to work, the server has to be configured to use domain authentication, _not_ NTLM authentication. The repository URL can be obtained from the TFS web interface, it may look like http://server.example.com:8080/tfs/TWA/TeamDev/_git/reponame. In order to instruct git to use domain authentication, prefix the server name with `:@`, like so: `http://:@server.example.com:8080/tfs/TWA/TeamDev/_git/reponame`. This is a special case of the usual `username:password@server` syntax, where both the `username` and `password` fields are empty. This causes git to look up and use your domain credentials. + +## I get "Permission denied (publickey)." when using git pull + +Some DSA keys are not considered secure anymore by OpenSSH 7. Adding "PubkeyAcceptedKeyTypes ssh-dss" to ~/.ssh/config helps. \ No newline at end of file From 3ad22003c44f23fcee88b998bb9eec365407c479 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Thu, 8 Oct 2015 13:30:15 +0200 Subject: [PATCH 148/591] Explain that `ln -s` does *not* do what you think it does. And hint at the tool that does what you want. --- Symbolic-Links.md | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/Symbolic-Links.md b/Symbolic-Links.md index 85d5c911b41984..55cf7eb22bd74a 100644 --- a/Symbolic-Links.md +++ b/Symbolic-Links.md @@ -11,4 +11,15 @@ For those reasons, Git for Windows disables support for symbolic links by defaul ```sh git clone -c core.symlinks=true +``` + +# Creating symbolic links + +By default, the `ln -s` command in *Git Bash* does *not* create symbolic links. Instead, it creates copies. + +To create symbolic links (provided your account has permission to do so), use the `mklink.exe` tool, like so: + +```cmd +mklink /d this-link-points-to c:\that-directory +mklink this-link-points-to c:\that-file ``` \ No newline at end of file From 667fa832cbce8bf04eb920898f561852c36c7e33 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Mon, 12 Oct 2015 11:58:44 +0200 Subject: [PATCH 149/591] Whoops. I did not mention that contributions are preferred as Pull Requests... --- How-to-participate.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/How-to-participate.md b/How-to-participate.md index 998b27ebb357ef..6695206a54b373 100644 --- a/How-to-participate.md +++ b/How-to-participate.md @@ -13,3 +13,5 @@ A lot of documentation wants to be written, still. A good place is [the Git for Download [the SDK](http://git-for-windows.github.io/#download-sdk) and build Git. Also have a look at [this page](https://github.com/git-for-windows/git/wiki/Building-Git) for tips and tricks revolving around building and debugging Git. Please also sign off your work, as [asked by the Git project](https://github.com/git/git/blob/v2.3.5/Documentation/SubmittingPatches#L234-L286) + +After that, submit a Pull Request. \ No newline at end of file From bc2a70608a3618d8294fc2e0459976dae1651ef5 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Wed, 14 Oct 2015 12:57:50 +0200 Subject: [PATCH 150/591] Start the page --- Contact.md | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) create mode 100644 Contact.md diff --git a/Contact.md b/Contact.md new file mode 100644 index 00000000000000..3c0123b7fe580d --- /dev/null +++ b/Contact.md @@ -0,0 +1,17 @@ +Please state the nature of your medical emergency. + +# I found a bug! + +Please follow [our guide lines](https://github.com/git-for-windows/git/wiki/Issue-reporting-guidelines) on reporting bugs. + +# I have a question! + +We have a [mailing list](https://groups.google.com/forum/#!forum/git-for-windows). It is actually a Google Group which can be used as if it were a forum, too. + +## But I really have only a quick question! + +There is a [chat room](https://gitter.im/git-for-windows/git). + +## But I would prefer to email somebody directly! + +Please keep in mind that the time of competent Open Sourcerers is better spent on communicating publicly. \ No newline at end of file From bcc879cbc957439a24823524ba2b9126278afb02 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Tue, 20 Oct 2015 19:44:35 +0200 Subject: [PATCH 151/591] Let's use the up-to-date link for the Developer's Certificate of Origin --- Good-commits.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Good-commits.md b/Good-commits.md index 75ee091f653664..8bb0b820b1266a 100644 --- a/Good-commits.md +++ b/Good-commits.md @@ -17,7 +17,7 @@ If you tried several strategies to solve your problem, you will want to describe Also important: - The commit message should always start with a single, short line summarizing the change. -- [Sign off](https://github.com/git/git/blob/v2.5.0/Documentation/SubmittingPatches#L234-L286) on your change (i.e. state that you release this patch as Open Source, if applicable with your employer's consent). +- [Sign off](https://github.com/git/git/blob/v2.6.2/Documentation/SubmittingPatches#L234-L286) on your change (i.e. state that you release this patch as Open Source, if applicable with your employer's consent). - Format the commit message to wrap at 76 columns per line. A good example for a commit message is [git-for-windows/build-extra@a64fe115](github.com/git-for-windows/build-extra/commit/a64fe115d901cab775c881bd1624218ac28de4d4): From 355a32efefd5d24c31ca9a3767ec4d1d69fce3bb Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Mon, 9 Nov 2015 15:13:49 +0100 Subject: [PATCH 152/591] This is a rough first version to get @ablaylock going in https://github.com/git-for-windows/git/issues/439 --- Debugging-Git.md | 9 +++++++++ 1 file changed, 9 insertions(+) create mode 100644 Debugging-Git.md diff --git a/Debugging-Git.md b/Debugging-Git.md new file mode 100644 index 00000000000000..a6c7b79d5935d7 --- /dev/null +++ b/Debugging-Git.md @@ -0,0 +1,9 @@ +# Debugging Git using the GNU debugger (GDB) + +First of all, Git's `.exe` files should be rebuilt with debugging information, and without optimization (because `gdb` has serious troubles single-stepping code compiled using `-O2` for some reason). To this end, [install the Git for Windows SDK](https://git-for-windows.github.io/#download-sdk), edit `/usr/src/git/Makefile` to remove the `-O2` from the `CFLAGS = -g -O2 -Wall` line and then run `make` in `/usr/src/git/`. + +After that, you can run Git's executables in GDB like so: + +```sh +gdb --args ./git.exe --exec-path=/usr/src/git rev-parse HEAD +``` \ No newline at end of file From 2332d62fc88d957d398626730a55436b473067cd Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Tue, 10 Nov 2015 19:35:08 +0000 Subject: [PATCH 153/591] Explain how to set a break point to when an error message is about to be printed --- Debugging-Git.md | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) diff --git a/Debugging-Git.md b/Debugging-Git.md index a6c7b79d5935d7..254ebbb2dacf59 100644 --- a/Debugging-Git.md +++ b/Debugging-Git.md @@ -6,4 +6,15 @@ After that, you can run Git's executables in GDB like so: ```sh gdb --args ./git.exe --exec-path=/usr/src/git rev-parse HEAD -``` \ No newline at end of file +``` + +## Stopping at certain errors + +Sometimes it is useful to ask the debugger to pause the program when the code path is entered that outputs an error message. The functions in Git that output error messages are `error_builtin()` and `die_builtin()`. So you can set the breakpoints + +``` +b error_builtin +b die_builtin +``` + +before calling `run` in `gdb` to stop execution at the appropriate time. \ No newline at end of file From 3a1258604e0dab4d446f18d8e43a29c5a0300caa Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Fri, 20 Nov 2015 11:35:24 +0100 Subject: [PATCH 154/591] Provide a TL;DR for @ferventcoder --- Symbolic-Links.md | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/Symbolic-Links.md b/Symbolic-Links.md index 55cf7eb22bd74a..62ae823b641968 100644 --- a/Symbolic-Links.md +++ b/Symbolic-Links.md @@ -1,3 +1,7 @@ +Short version: there is no exact equivalent for POSIX symlinks on Windows, and the closest thing is unavailable for non-admins by default. Therefore, symlink emulation support is switched off by default and needs to be configured by you, the user, via the `core.symlinks=true` config setting. + +# Background + Starting with Windows Vista, there is support for symbolic links. These are not your grandfather's Unix symbolic links; They differ in quite a couple of ways: - Symbolic links are only available on Windows Vista and later, most notably not on XP From 2e2da5b75622c146ae8fc88fe0c0e6187e3fccc1 Mon Sep 17 00:00:00 2001 From: dshope247 Date: Sun, 29 Nov 2015 16:32:05 -0500 Subject: [PATCH 155/591] Updated Issue reporting guidelines (markdown) From d0691dbc6f06359c484a268542e9292204b0b813 Mon Sep 17 00:00:00 2001 From: steswi Date: Thu, 10 Dec 2015 17:55:29 +0100 Subject: [PATCH 156/591] Updated FAQ (markdown) --- FAQ.md | 12 +++++++++++- 1 file changed, 11 insertions(+), 1 deletion(-) diff --git a/FAQ.md b/FAQ.md index a45db9e53c7e59..d090f4764577f9 100644 --- a/FAQ.md +++ b/FAQ.md @@ -33,4 +33,14 @@ In order to instruct git to use domain authentication, prefix the server name wi ## I get "Permission denied (publickey)." when using git pull -Some DSA keys are not considered secure anymore by OpenSSH 7. Adding "PubkeyAcceptedKeyTypes ssh-dss" to ~/.ssh/config helps. \ No newline at end of file +Some DSA keys are not considered secure anymore by OpenSSH 7. Adding "PubkeyAcceptedKeyTypes ssh-dss" to ~/.ssh/config helps. + +## Switch locale for git-bash launcher in windows + +Some developers want to start git-bash with a different language. +To achive this in windows following command could be place inside the launcher: +C:\Windows\System32\cmd.exe /c "set LANG=en_GB && start C:\git-sdk-64\git-bash.exe && exit" +Replace "en_GB" with your preferred locale. + + + From 0c47cc25e6bcd36975bd44d04b4fa99202a8bf2a Mon Sep 17 00:00:00 2001 From: steswi Date: Thu, 10 Dec 2015 17:57:44 +0100 Subject: [PATCH 157/591] Updated FAQ (markdown) --- FAQ.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/FAQ.md b/FAQ.md index d090f4764577f9..a27e39595029fe 100644 --- a/FAQ.md +++ b/FAQ.md @@ -37,8 +37,8 @@ Some DSA keys are not considered secure anymore by OpenSSH 7. Adding "PubkeyAcce ## Switch locale for git-bash launcher in windows -Some developers want to start git-bash with a different language. -To achive this in windows following command could be place inside the launcher: +Some developers want to start git-bash (of Git SDK for Windows) with a different language. +To achive this in windows following command could be placed inside the launcher: C:\Windows\System32\cmd.exe /c "set LANG=en_GB && start C:\git-sdk-64\git-bash.exe && exit" Replace "en_GB" with your preferred locale. From 0fc49174cfb5fc2c8e7f38e696f6de196dd692ca Mon Sep 17 00:00:00 2001 From: steswi Date: Thu, 10 Dec 2015 17:59:52 +0100 Subject: [PATCH 158/591] Updated FAQ (markdown) --- FAQ.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/FAQ.md b/FAQ.md index a27e39595029fe..2b8614d52e59cb 100644 --- a/FAQ.md +++ b/FAQ.md @@ -35,9 +35,9 @@ In order to instruct git to use domain authentication, prefix the server name wi Some DSA keys are not considered secure anymore by OpenSSH 7. Adding "PubkeyAcceptedKeyTypes ssh-dss" to ~/.ssh/config helps. -## Switch locale for git-bash launcher in windows +## Switch locale for git-bash launcher (of Git for Windows SDK) -Some developers want to start git-bash (of Git SDK for Windows) with a different language. +Some developers want to start git-bash (of Git for Windows SDK) with a different language. To achive this in windows following command could be placed inside the launcher: C:\Windows\System32\cmd.exe /c "set LANG=en_GB && start C:\git-sdk-64\git-bash.exe && exit" Replace "en_GB" with your preferred locale. From 498381e67fc3a079a3146fc5051947910699d13b Mon Sep 17 00:00:00 2001 From: Jan Schulz Date: Wed, 6 Jan 2016 22:25:25 +0100 Subject: [PATCH 159/591] Update make commands for documentation updates (missing git-subtree.html file) --- Making-a-portable-Git.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Making-a-portable-Git.md b/Making-a-portable-Git.md index a8901b45a32704..b896752d47317c 100644 --- a/Making-a-portable-Git.md +++ b/Making-a-portable-Git.md @@ -1,4 +1,4 @@ -As the portable Git is made by putting together files from the Git SDK, it is advisable to update those files first. To update the packages, call `pacman -Syu` ([caveats apply](https://github.com/git-for-windows/git/wiki/Package-management#updating-msys2-runtime-pacman-and-bash)). If you want to test Git changes or make an portable Git from your own Git fork, you need to call `cd /usr/src/git && make install` (for documentation changes, `make install-html`). +As the portable Git is made by putting together files from the Git SDK, it is advisable to update those files first. To update the packages, call `pacman -Syu` ([caveats apply](https://github.com/git-for-windows/git/wiki/Package-management#updating-msys2-runtime-pacman-and-bash)). If you want to test Git changes or make an portable Git from your own Git fork, you need to call `cd /usr/src/git && make install` (for documentation changes, `make install-html` and *afterwards* `prefix=/mingw64 make -C contrib/subtree install-html` - without the second `make` you get a error message about a missing `git-subtree.html` file). To package the portable Git, install the [SDK](https://git-for-windows.github.io/#download-sdk), run it and then issue the following commands: From dc6a766edee58b34749be63ca4703a0b66f9d621 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Thu, 7 Jan 2016 14:46:02 +0100 Subject: [PATCH 160/591] Update make commands for documentation updates (missing git-subtree.html file) --- Making-an-installer.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Making-an-installer.md b/Making-an-installer.md index c689ee903335d4..f860411324454f 100644 --- a/Making-an-installer.md +++ b/Making-an-installer.md @@ -1,4 +1,4 @@ -As the installer is made by putting together files from the Git SDK, it is advisable to update those files first. To update the packages, call `pacman -Syu` ([caveats apply](https://github.com/git-for-windows/git/wiki/Package-management#updating-msys2-runtime-pacman-and-bash)). If you want to test Git changes or make an installer from your own Git fork, you need to call `cd /usr/src/git && make install` (for documentation changes, `make install-html`). +As the installer is made by putting together files from the Git SDK, it is advisable to update those files first. To update the packages, call `pacman -Syu` ([caveats apply](https://github.com/git-for-windows/git/wiki/Package-management#updating-msys2-runtime-pacman-and-bash)). If you want to test Git changes or make an installer from your own Git fork, you need to call `cd /usr/src/git && make install` (for documentation changes, `make install-html` and *afterwards* `prefix=/mingw64 make -C contrib/subtree install-html` - without the second `make` you get a error message about a missing `git-subtree.html` file). To make an installer, install the [SDK](https://git-for-windows.github.io/#download-sdk), run it and then issue the following commands: From cb3a2c794bdde1c9fb1ab2471a3ea95dfa8f7e55 Mon Sep 17 00:00:00 2001 From: Jan Schulz Date: Fri, 8 Jan 2016 23:18:52 +0100 Subject: [PATCH 161/591] New page for newbies --- ...-started:-building-your-own-git-package.md | 61 +++++++++++++++++++ 1 file changed, 61 insertions(+) create mode 100644 Getting-started:-building-your-own-git-package.md diff --git a/Getting-started:-building-your-own-git-package.md b/Getting-started:-building-your-own-git-package.md new file mode 100644 index 00000000000000..7ae95b8a78e8d5 --- /dev/null +++ b/Getting-started:-building-your-own-git-package.md @@ -0,0 +1,61 @@ +The process to build installer is made easy via the `Git for Windows SDK`. The steps are basically: + +1. Download and install the SDK, which installs the sources for `git`, additional msys and mingw packages and helpers to build the installer and provides the `Git for Windows SDK` MSys shell +2. [optional] Hack in the changes you want and make these changes available to the installer. +3. Call the right helper tools to build the package you want. + +# Installing the SDK + +Download the [SDK](https://git-for-windows.github.io/#download-sdk) and run it. You will end up with a console window running the `Git for Windows SDK` MSys shell, which you can use for the next steps. Git is already checked out and the latest version build and installed, so if you just want to build an installer from latest master, you are ready to go. + +You can open the `Git for Windows SDK` MSys shell by double clicking `msys2_shell.bat` in the install folder (i.e. not the MinGW 32-bit nor the MinGW 64-bit one). + +As the installer is made by putting together files from the Git SDK, it is advisable to update those files first. To update the packages, call `pacman -Syu` ([caveats apply](https://github.com/git-for-windows/git/wiki/Package-management#updating-msys2-runtime-pacman-and-bash)). + +# Hacking on git + +If you only want an installer of the latest version of git (master), then you can skip this step. + +The sources of git are checked out in `/usr/src/git`. [Hack in (and test)](Building-Git) the changes you want... + +Afterwards you need to install git to make these changes available to the installer build: `cd /usr/src/git && make install`. + +If you made any documentation changes, you need to install the documentation too: `make install-html && prefix=/mingw64 make -C contrib/subtree install-html` (the second make invocation installs the `git-subtree.html` which is otherwise missing and leads to an error by the portable installer). + +In some cases the change you want to make is not in git itself but in the additional files needed to emulate the *ix environment git expects (things like `grep`, `find`, `cat`,...) or in additional helper files (e.g. `start-ssh-agent.cmd`). These files come from [Msys](https://github.com/git-for-windows/MSYS2-packages) and [Mingw](https://github.com/git-for-windows/MINGW-packages) packages. Please see the documentation how to make [changes to these packages](Package-management#technical-details). Some files are also in the `build-extras` repo in the subdir [`git-extra`](https://github.com/git-for-windows/build-extra/tree/master/git-extra) (the script which calls notepad as a commit message editor, diff filter for word files,...). The source code for these files are also under `/usr/src` but need to checked out first (e.g. `cd /usr/src/MINGW-packages && git fetch && git checkout master`). + +# Building an installer + +You can build both a normal setup installer and a portable one. + +The installers are basically created by collecting files from the `Git for Windows SDK` Msys environment, not from any checked out source code! It's therefore important to make any changed files available to the installer (the `make` calls in the "Hacking on git" step)! + +As a one time step, you need to prepare the extra files which contain the helper scripts: + +```bash +cd /usr/src/build-extra +git fetch +git checkout master +``` + +The next step depends on whether you want a normal setup-based installer or a portable installer: + +To build a setup based one: + +```bash +./installer/release.sh -test +``` +where `` is the Git version. + +To build a portable installer, use: + +```bash +./portable/release.sh -test +``` +The last line of the log shows where the installer packages were created (usually in your user directory: `c:\Users\ `). + +See also: +* [Debugging git](Debugging-Git) with gdb +* Running Git's [regression tests](Running-Git's-regression-tests) +* Msys/Mingw [package management](Package-management#technical-details) +* [Updating the SDK](https://github.com/git-for-windows/git/wiki/Updating-your-SDK) \ No newline at end of file From 76c49b9f8a2ad07a924813b232856d47565e48b3 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Mon, 11 Jan 2016 10:13:08 +0100 Subject: [PATCH 162/591] Rename page so it can be checked out on NTFS Signed-off-by: Johannes Schindelin --- ...ted:-building-your-own-git-package.md => Technical-overview.md | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename Getting-started:-building-your-own-git-package.md => Technical-overview.md (100%) diff --git a/Getting-started:-building-your-own-git-package.md b/Technical-overview.md similarity index 100% rename from Getting-started:-building-your-own-git-package.md rename to Technical-overview.md From 2ed9536a0fcee2cdc96d74d72f2c42f2e74d5792 Mon Sep 17 00:00:00 2001 From: Jan Schulz Date: Mon, 11 Jan 2016 22:40:15 +0100 Subject: [PATCH 163/591] Update to new start-ssh-agent script --- Auto-launching-ssh-agent-when-git-starts.md | 63 +++------------------ 1 file changed, 7 insertions(+), 56 deletions(-) diff --git a/Auto-launching-ssh-agent-when-git-starts.md b/Auto-launching-ssh-agent-when-git-starts.md index 3b85b339707dea..088acfd0dd18d7 100644 --- a/Auto-launching-ssh-agent-when-git-starts.md +++ b/Auto-launching-ssh-agent-when-git-starts.md @@ -1,60 +1,11 @@ -If you want your passphrase to be 'remembered' for a session (or configurable timeout period) you will need to setup an ssh-agent process to handle this key. Github provides excellent instructions for this here: https://help.github.com/articles/working-with-ssh-key-passphrases/#auto-launching-ssh-agent-on-msysgit +If you want your passphrase to be 'remembered' for a session (or configurable timeout period) you will need to setup an ssh-agent process to handle this key. -**However** if you follow these instructions you will be unable to install git for windows 2.x (it will hang waiting for the ssh-add.exe process to be killed.) +Recent versions of git for windows 2.x come with an ssh agent startup script and the installer also checks if an ssh agent is currently running and asks you to kill this process. -To avoid this issue, if you use the following script (based on that provided above) you will be able to install and upgrade git for windows 2.x +Run the ssh agent: - # Note: ~/.ssh/environment should not be used, as it - # already has a different purpose in SSH. - - env=~/.ssh/agent.env - - # Note: Don't bother checking SSH_AGENT_PID. It's not used - # by SSH itself, and it might even be incorrect - # (for example, when using agent-forwarding over SSH). - - agent_is_running() { - if [ "$SSH_AUTH_SOCK" ]; then - # ssh-add returns: - # 0 = agent running, has keys - # 1 = agent running, no keys - # 2 = agent not running - ssh-add -l >/dev/null 2>&1 || [ $? -eq 1 ] - else - false - fi - } - - agent_has_keys() { - ssh-add -l >/dev/null 2>&1 - } - - agent_load_env() { - . "$env" >/dev/null - } - - agent_start() { - (umask 077; ssh-agent >"$env") - . "$env" >/dev/null - } - - # We only want to fire up ssh-agent when in an interactive session. - case "$-" in - *i*) - if ! agent_is_running; then - agent_load_env - fi - - # if your keys are not stored in ~/.ssh/id_rsa or ~/.ssh/id_dsa, you'll need - # to paste the proper path after ssh-add - if ! agent_is_running; then - agent_start - ssh-add - elif ! agent_has_keys; then - ssh-add - fi - - unset env - ;; - esac + start-ssh-agent.cmd +This should work in both a `cmd` and `bash` and can be included in `~/.profile` or `~/.bashrc`. + +The [Github instructions](https://help.github.com/articles/working-with-ssh-key-passphrases/#auto-launching-ssh-agent-on-msysgit) are still valid but not needed anymore. \ No newline at end of file From 8e33243389b477d0bb3abbbd2496f3c32e12f520 Mon Sep 17 00:00:00 2001 From: Jan Schulz Date: Mon, 11 Jan 2016 22:40:59 +0100 Subject: [PATCH 164/591] minor typo corrections --- Auto-launching-ssh-agent-when-git-starts.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Auto-launching-ssh-agent-when-git-starts.md b/Auto-launching-ssh-agent-when-git-starts.md index 088acfd0dd18d7..ee37766b4cdd29 100644 --- a/Auto-launching-ssh-agent-when-git-starts.md +++ b/Auto-launching-ssh-agent-when-git-starts.md @@ -6,6 +6,6 @@ Run the ssh agent: start-ssh-agent.cmd -This should work in both a `cmd` and `bash` and can be included in `~/.profile` or `~/.bashrc`. +This should work both in a `cmd` and `bash` shell and can be included in `~/.profile` or `~/.bashrc`. The [Github instructions](https://help.github.com/articles/working-with-ssh-key-passphrases/#auto-launching-ssh-agent-on-msysgit) are still valid but not needed anymore. \ No newline at end of file From af7c6c8e6f9a60491f505a1cc1f039d1e13127ef Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Wed, 20 Jan 2016 07:23:35 +0100 Subject: [PATCH 165/591] Use the preferred spelling of the MSYS2 project While it does not make sense to pretend that the project name is a four-letter acronym (it really stands for "Minimal System"), it is definitely not worth an issue to fight over. We have much bigger fish to fry. Signed-off-by: Johannes Schindelin --- 32-bit-issues.md | 20 ++++++++++---------- Building-Git.md | 2 +- Building-msys2-runtime.md | 2 +- Home.md | 10 +++++----- MSYS2-Notes.md | 4 ++-- Package-management.md | 12 ++++++------ Running-Git's-regression-tests.md | 6 +++--- Updating-your-SDK.md | 10 +++++----- 8 files changed, 33 insertions(+), 33 deletions(-) diff --git a/32-bit-issues.md b/32-bit-issues.md index cd1b2a02ea4955..ab5d958414e60d 100644 --- a/32-bit-issues.md +++ b/32-bit-issues.md @@ -2,27 +2,27 @@ Note that typically, there is no problem because the solution described [here](#adjusting-msys-20dlls-address-range-manually) is executed preventively upon installation of Git for Windows. -The problem only resurfaces if a `.dll` has been installed *after* Git for Windows' installation and only if that `.dll` [interferes with the address range hard-coded into the MSys2 runtime](#background). +The problem only resurfaces if a `.dll` has been installed *after* Git for Windows' installation and only if that `.dll` [interferes with the address range hard-coded into the MSYS2 runtime](#background). -The simplest solution to fix that problem if it rears its ugly head at all is to switch to the 64-bit version of Git for Windows (the 64-bit address range is so large that MSys2's runtime virtually never has any run-in with another `.dll`). +The simplest solution to fix that problem if it rears its ugly head at all is to switch to the 64-bit version of Git for Windows (the 64-bit address range is so large that MSYS2's runtime virtually never has any run-in with another `.dll`). The second-simplest solution is to [reinstall Git for Windows](#reinstall-git-for-windows). # Background -Git for Windows is not just a version of Git compiled and packaged for yet another Operating System. Many parts of Git are written in script languages (e.g. POSIX shell or Perl) and therefore Git for Windows has to bundle such script interpreters as well. In particular `bash.exe` (which is used by Git for Windows to execute POSIX shell scripts) expects a POSIX environment which is not available on Windows. The Git for Windows project uses [MSys2](https://msys2.github.io/) (essentially a [portable](https://en.wikipedia.org/wiki/Portable_application) version of [Cygwin](https://cygwin.com/)) to provide the POSIX emulation layer. +Git for Windows is not just a version of Git compiled and packaged for yet another Operating System. Many parts of Git are written in script languages (e.g. POSIX shell or Perl) and therefore Git for Windows has to bundle such script interpreters as well. In particular `bash.exe` (which is used by Git for Windows to execute POSIX shell scripts) expects a POSIX environment which is not available on Windows. The Git for Windows project uses [MSYS2](https://msys2.github.io/) (essentially a [portable](https://en.wikipedia.org/wiki/Portable_application) version of [Cygwin](https://cygwin.com/)) to provide the POSIX emulation layer. ## The problem with `fork()` One of the most crucial POSIX calls expected by Bash is the `fork()` call. It starts a new process, inheriting the current process' memory contents, file descriptors and other resources. And it has no equivalent in the Win32 API (`fork()`'s closest Win32 relative is `CreateProcess()` which spawns a new process, inheriting nothing at all by default). -To make it possible to emulate `fork()`, Cygwin -- and therefore MSys2 -- needs to make certain assumptions about its core ("runtime") library called `cygwin1.dll` -- or `msys-2.0.dll`. In particular, it needs to pin it to a known address range to detect in child processes that there is a parent process already, and to copy the relevant data from there. +To make it possible to emulate `fork()`, Cygwin -- and therefore MSYS2 -- needs to make certain assumptions about its core ("runtime") library called `cygwin1.dll` -- or `msys-2.0.dll`. In particular, it needs to pin it to a known address range to detect in child processes that there is a parent process already, and to copy the relevant data from there. That works very well. Until another `.dll` has been loaded into memory already, into a location that interferes with the hard-coded address range of the runtime. It is unfortunately not possible to catch that problem in a user-friendly way because there is no Win32 API call that can ask "has this address range been used by this and that `.dll`?". ## The symptom of an address range that needs adjusting -When there is already a `.dll` interfering with MSys2's runtime's hard-coded address range, the user will be greeted by this error message when calling Bash : +When there is already a `.dll` interfering with MSYS2's runtime's hard-coded address range, the user will be greeted by this error message when calling Bash : ``` > sh.exe @@ -36,7 +36,7 @@ There are several ways how to get out of this problem: ## Upgrade to the 64-bit version of Git for Windows -The address range available in 64-bit Windows is so large as to virtually guarantee that the address range of the MSys2 runtime never has to be adjusted. This is by far the easiest solution, now that Git for Windows 2.x offers a 64-bit version. +The address range available in 64-bit Windows is so large as to virtually guarantee that the address range of the MSYS2 runtime never has to be adjusted. This is by far the easiest solution, now that Git for Windows 2.x offers a 64-bit version. ## Reinstall Git for Windows @@ -44,17 +44,17 @@ If you cannot switch to 64-bit for any reason, reinstalling Git for Windows will ## Adjusting `msys-2.0.dll`'s address range manually -To fix the problem of address range overlaps, MSys2 offers a utility called `rebase.exe` (which confusingly has nothing at all to do with `git rebase`) to adjust the address range of a given set of `.dll` files. +To fix the problem of address range overlaps, MSYS2 offers a utility called `rebase.exe` (which confusingly has nothing at all to do with `git rebase`) to adjust the address range of a given set of `.dll` files. Unfortunately the [symptom](#the-symptom-of-an-address-range-that-needs-adjusting) occurs not all that rarely, therefore there is even a script to make `rebase.exe` more convenient to use: `/usr/bin/rebaseall`. This script is meant to be executed via Dash instead of Bash, to avoid chicken-and-egg problems with Bash not being able to run properly unless the address range is already fixed. Typically it is unnecessary to run this script manually because it is run as part of Git for Windows' installation process. If the [symptom](#the-symptom-of-an-address-range-that-needs-adjusting) occurs at some stage long after Git for Windows was installed, reinstalling Git for Windows is the most convenient way to fix it. -If you still insist on fixing it manually, please understand that this is *not* recommended without knowledge of MSys2 internals (read: if you get stuck, please do not open a ticket to learn more about MSys2; use the recommended way instead: reinstall Git for Windows). The manual way goes like this: +If you still insist on fixing it manually, please understand that this is *not* recommended without knowledge of MSYS2 internals (read: if you get stuck, please do not open a ticket to learn more about MSYS2; use the recommended way instead: reinstall Git for Windows). The manual way goes like this: 1. close each and every `mintty` window 2. terminate each and every Bash -3. terminate even background processes that use the MSys2 runtime, such as `ssh-agent` +3. terminate even background processes that use the MSYS2 runtime, such as `ssh-agent` 4. open `cmd.exe`, change the directory to Git's top-level one and then run ```cmd usr\bin\dash -c '/usr/bin/dash /usr/bin/rebaseall -p' - ``` \ No newline at end of file + ``` diff --git a/Building-Git.md b/Building-Git.md index 90996065545a81..7f5021eb7f40ce 100644 --- a/Building-Git.md +++ b/Building-Git.md @@ -1,4 +1,4 @@ -We build Git for Windows using an [MSys2](https://msys2.github.io/) based *Git for Windows SDK*. This SDK can be installed via the [SDK installer](https://git-for-windows.github.io/#download-sdk) +We build Git for Windows using an [MSYS2](https://msys2.github.io/) based *Git for Windows SDK*. This SDK can be installed via the [SDK installer](https://git-for-windows.github.io/#download-sdk) # Installing a build environment diff --git a/Building-msys2-runtime.md b/Building-msys2-runtime.md index 2958f6f65fdd8c..8acad34e26d59b 100644 --- a/Building-msys2-runtime.md +++ b/Building-msys2-runtime.md @@ -6,7 +6,7 @@ 1. Open the *Git for Windows SDK* *MSys* shell by double clicking `msys2_shell.bat` in the install folder. (i.e. not the *MinGW 32-bit* nor the *MinGW 64-bit* one). -2. Install the MSys2 Toolchain: `pacman -S base-devel`. +2. Install the MSYS2 Toolchain: `pacman -S base-devel`. 3. Initialize the local MSYS2-packages clone: `cd /usr/src/MSYS2-packages && git fetch origin && git checkout master`. diff --git a/Home.md b/Home.md index cce3ec3d5e56ad..b5649f502b9548 100644 --- a/Home.md +++ b/Home.md @@ -12,15 +12,15 @@ This became really too tedious, so much so that there was not enough time to pro At some stage, it became obvious that there needs to be a better solution. [@sschuberth](https://github.com/sschuberth) had already started a [separate project](https://github.com/sschuberth/gfw-msys1-sdk) to leverage the package manager that _MSys_ had introduced at that stage, `mingw-get`. However, it turned out that the packages were not maintained all that well, and besides, _MSys_' runtime had not been kept up-to-date with [Cygwin](https://www.cygwin.com/), and was falling behind in terms of features and support. -In a two-hour Skype session about the course of _Git for Windows_ [@dscho](https://github.com/dscho), [@t-b](https://github.com/t-b) and [@sschuberth](https://github.com/sschuberth) decided to give [MSys2](https://msys2.github.io/) a whirl. _MSys2_ was started with the idea to restart the _MSys_ project, frequently updating with _Cygwin_ and just keeping the spirit of _MSys_ to provide a very stripped-down *POSIX* layer, essentially a bare-minimum version of _Cygwin_. _MSys2_ also sports a package manager (`pacman`) and keeps those packages up-to-date very well. Another bonus: _MSys2_ is available for `64-bit` in addition to `32-bit`, while _MSys_ was stuck with `32-bit`. +In a two-hour Skype session about the course of _Git for Windows_ [@dscho](https://github.com/dscho), [@t-b](https://github.com/t-b) and [@sschuberth](https://github.com/sschuberth) decided to give [MSYS2](https://msys2.github.io/) a whirl. _MSYS2_ was started with the idea to restart the _MSys_ project, frequently updating with _Cygwin_ and just keeping the spirit of _MSys_ to provide a very stripped-down *POSIX* layer, essentially a bare-minimum version of _Cygwin_. _MSYS2_ also sports a package manager (`pacman`) and keeps those packages up-to-date very well. Another bonus: _MSYS2_ is available for `64-bit` in addition to `32-bit`, while _MSys_ was stuck with `32-bit`. -Thanks to sponsoring of _GitHub_, [@dscho](https://github.com/dscho) could afford to spend the time to investigate the possibilities with _MSys2_. It turned out that _MSys2_ already provided most of the parts needed, and would make maintenance much, much easier. [@dscho](https://github.com/dscho) (and others too) really spent an insane amount of time (thanks GitHub!) to get everything up to speed, even fixing a couple of long-standing bugs in _Git for Windows_. It essentially came down to modifying the `msys2-runtime` to _Git for Windows_ needs. The rest is basically upstream _MSys2_ architecture. +Thanks to sponsoring of _GitHub_, [@dscho](https://github.com/dscho) could afford to spend the time to investigate the possibilities with _MSYS2_. It turned out that _MSYS2_ already provided most of the parts needed, and would make maintenance much, much easier. [@dscho](https://github.com/dscho) (and others too) really spent an insane amount of time (thanks GitHub!) to get everything up to speed, even fixing a couple of long-standing bugs in _Git for Windows_. It essentially came down to modifying the `msys2-runtime` to _Git for Windows_ needs. The rest is basically upstream _MSYS2_ architecture. -And yes, the idea is still the same as the original one: Update the _MSys2_ setup, together with a _Git_ package built from _Git for Windows_' source code, then bundle the relevant files together with a couple of extra files into an installer. Then I sign it and upload it. And that is _Git for Windows_ 2.x. +And yes, the idea is still the same as the original one: Update the _MSYS2_ setup, together with a _Git_ package built from _Git for Windows_' source code, then bundle the relevant files together with a couple of extra files into an installer. Then I sign it and upload it. And that is _Git for Windows_ 2.x. -Now, keep in mind that _MSys2_ and Linux (The original target for _Git_'s distribution) are very different beasts. Their distributions might include packages that are built from the same source code (i.e. the `binutils`, `gcc` or `bash` package), but the runtime is very, very different: _MSys2_'s runtime is a stripped-down, slightly modified _Cygwin_ runtime running on top of the Windows kernel, while Linux' runtime is the Linux kernel, running as a separate OS altogether. +Now, keep in mind that _MSYS2_ and Linux (The original target for _Git_'s distribution) are very different beasts. Their distributions might include packages that are built from the same source code (i.e. the `binutils`, `gcc` or `bash` package), but the runtime is very, very different: _MSYS2_'s runtime is a stripped-down, slightly modified _Cygwin_ runtime running on top of the Windows kernel, while Linux' runtime is the Linux kernel, running as a separate OS altogether. So if you are missing some packages - feel free to start making one. This is Open Source, however, so everybody interested and capable enough can contribute whatever they need to address their needs. And that includes you: you could imitate e.g. [a simple `PKGBUILD` file](https://github.com/Alexpux/MINGW-packages/blob/master/mingw-w64-assimp-git/PKGBUILD) to build a new package e.g. `msmtp`, the component that _Git for Windows_ 1.x uses to support `sendemail`. Then open a Pull Request so that _Git for Windows_ can ship it. Our documentation will be helpful in that endeavor: [package-management](https://github.com/git-for-windows/git/wiki/Package-management), in particular [package-management#rebuild-packages](https://github.com/git-for-windows/git/wiki/Package-management#rebuild-packages). # Start documenting -If you need inspiration what you could write about: document your common work flows. Write a tutorial how to start coding _Git for Windows_, how to run the test suite. Write a tutorial how to debug a failing test. Write about something you would have wished you had known about Git for Windows a long time ago. \ No newline at end of file +If you need inspiration what you could write about: document your common work flows. Write a tutorial how to start coding _Git for Windows_, how to run the test suite. Write a tutorial how to debug a failing test. Write about something you would have wished you had known about Git for Windows a long time ago. diff --git a/MSYS2-Notes.md b/MSYS2-Notes.md index d594bc05f80575..aa0197deef932d 100644 --- a/MSYS2-Notes.md +++ b/MSYS2-Notes.md @@ -1,4 +1,4 @@ -Page for things that pop up while fiddling with MSys2. +Page for things that pop up while fiddling with MSYS2. # PS1 script @@ -78,4 +78,4 @@ This means the `_vimrc` have CRLF end line style instead of LF. You can either u ``` dos2unix $HOME/_vimrc -``` \ No newline at end of file +``` diff --git a/Package-management.md b/Package-management.md index 5594d1aea5ff73..a8aa313642359c 100644 --- a/Package-management.md +++ b/Package-management.md @@ -1,6 +1,6 @@ Modern software development relies heavily on a way to manage dependencies, i.e. to keep track of required software libraries and their versions. Examples are `apt-get` for Linux, `homebrew` for MacOSX, `Maven` for Java and `pip` for Python. -Git for Windows is based on [MSys2](https://msys2.github.io/) which bundles Arch Linux' [Pacman](https://wiki.archlinux.org/index.php/Pacman) tool for dependency management. +Git for Windows is based on [MSYS2](https://msys2.github.io/) which bundles Arch Linux' [Pacman](https://wiki.archlinux.org/index.php/Pacman) tool for dependency management. # How to use `pacman` @@ -28,9 +28,9 @@ pacman -Syu ### Updating `msys2-runtime`, `pacman` and `bash` -As `pacman.exe` is itself an MSys2 executable, it is strongly suggested to update `msys2-runtime` and `pacman` packages individually if they need to be updated, and let `pacman` quit *immediately* afterwards. +As `pacman.exe` is itself an MSYS2 executable, it is strongly suggested to update `msys2-runtime` and `pacman` packages individually if they need to be updated, and let `pacman` quit *immediately* afterwards. -Likewise, if you run `pacman` from a `bash` -- an MSys2 program, too -- you should quit the shell *immediately* (it might show an infinite stream of heap messages instead of quitting, requiring to be force-quit). +Likewise, if you run `pacman` from a `bash` -- an MSYS2 program, too -- you should quit the shell *immediately* (it might show an infinite stream of heap messages instead of quitting, requiring to be force-quit). ## Remove packages @@ -82,7 +82,7 @@ To build MSys packages, you need to start the `MSys` shell (which sets `MSYSTEM= makepkg -s ``` -*Note*: Before building the first MSys package, as per [MSys2's own documentation](http://sourceforge.net/p/msys2/wiki/Contributing%20to%20MSYS2/) you need to install the development packages for development: +*Note*: Before building the first MSys package, as per [MSYS2's own documentation](http://sourceforge.net/p/msys2/wiki/Contributing%20to%20MSYS2/) you need to install the development packages for development: ```sh pacman -Sy base-devel msys2-devel @@ -128,7 +128,7 @@ perl -MCPAN -e shell Pacman repositories are served via HTTP, as static files in a single directory. The most important file in that directory is the *package index*, called `.db.tar.xz` by convention. This package index can be updated via `repo-add ...` (this updated *only* the package index, it does *not* copy the package files into the same directory). Pacman expects to find the package files referenced in the package index in the same directory as the index. The *Git for Windows*-specific packages are served from Bintray, see [below](#Bintray). -We ship MSys2 and MinGW packages for two architectures, [`i686`](https://dl.bintray.com/git-for-windows/pacman/i686/) and [`x86_64`](https://dl.bintray.com/git-for-windows/pacman/x86_64/). +We ship MSYS2 and MinGW packages for two architectures, [`i686`](https://dl.bintray.com/git-for-windows/pacman/i686/) and [`x86_64`](https://dl.bintray.com/git-for-windows/pacman/x86_64/). ## Bintray @@ -156,4 +156,4 @@ To upload new files, a maintainer needs to have permission to write to the `pacm The `fetch` step will initialize or synchronize the local mirror of the Pacman repository, the `add` step will copy the packages into the appropriate location, and the `push` step will update the package index, and upload the packages that are not yet on Bintray as well as the package index. -Note: The `pacman-mirror.sh` tool takes no precaution against simultaneous use. You *will* want to coordinate with your fellow maintainers to avoid running it at the same time as somebody else. \ No newline at end of file +Note: The `pacman-mirror.sh` tool takes no precaution against simultaneous use. You *will* want to coordinate with your fellow maintainers to avoid running it at the same time as somebody else. diff --git a/Running-Git's-regression-tests.md b/Running-Git's-regression-tests.md index b8e7dba13ded55..55e9344ed54b92 100644 --- a/Running-Git's-regression-tests.md +++ b/Running-Git's-regression-tests.md @@ -63,7 +63,7 @@ Some parts of Git are implemented as Perl scripts. To trigger execution tracing ### `GIT_TRACE=1` -When Git sees that the environment variable `GIT_TRACE` is set, it will print out an internal execution trace when Git wants to call external executables and builtins. This is extremely helpful in particular when debugging posix-to-windows mangling issues with the MSys2 runtime. All you do is to prefix the Git command to be executed in the test script with `GIT_TRACE=1 `, e.g. `GIT_TRACE=1 git difftool --extcmd "$2"`. +When Git sees that the environment variable `GIT_TRACE` is set, it will print out an internal execution trace when Git wants to call external executables and builtins. This is extremely helpful in particular when debugging posix-to-windows mangling issues with the MSYS2 runtime. All you do is to prefix the Git command to be executed in the test script with `GIT_TRACE=1 `, e.g. `GIT_TRACE=1 git difftool --extcmd "$2"`. ### Interactive Bash/GDB @@ -79,7 +79,7 @@ It gets even trickier when there is no `stdout`/`stderr` available (e.g. when de While it is a little cumbersome to add such debug print statements (after all, you typically have to rebuild the executables and run the tests from the top), there is also a big benefit to this technique over single-stepping: the debug output can be made conditional upon the particulars of the problem to be debugged. For example, instead of writing out information *every* time, say, `get_sha1_hex()` is called, it can be written out *only* the third time it is called with an SHA-1 beginning with two specific byte values. This technique can also be combined with single-stepping, by setting a breakpoint on that conditional debug output, saving a lot of time to get back to the same point after modifying and recompiling the source code. -There exist even more problematic situations when working on Git for Windows, though: when trying to figure out issues in the MSys2 runtime, there might not be any `fprintf(...)` functionality available at that point of execution (yet). In this case, you need to revert to the plain Win32 API to write into a file: +There exist even more problematic situations when working on Git for Windows, though: when trying to figure out issues in the MSYS2 runtime, there might not be any `fprintf(...)` functionality available at that point of execution (yet). In this case, you need to revert to the plain Win32 API to write into a file: ```c ... @@ -97,4 +97,4 @@ CloseHandle(h); } } ``` -Of course, if it is possible to write to `stderr` instead, the code should use `HANDLE h = GetStdHandle(STD_ERROR_HANDLE);` instead of the `CreateFile()` call instead, and *not* close the handle... \ No newline at end of file +Of course, if it is possible to write to `stderr` instead, the code should use `HANDLE h = GetStdHandle(STD_ERROR_HANDLE);` instead of the `CreateFile()` call instead, and *not* close the handle... diff --git a/Updating-your-SDK.md b/Updating-your-SDK.md index d9f9a58592ac87..73b10cc1ad1fd9 100644 --- a/Updating-your-SDK.md +++ b/Updating-your-SDK.md @@ -12,10 +12,10 @@ with 7-Zip need to run that batch file manually, too. The script is extensively commented to assist in understanding the installation process and issues. -The files contained in the net installer are parts of MSys2's +The files contained in the net installer are parts of MSYS2's 'msys2-runtime', 'pacman' and 'gnupg' packages, carefully selected to keep the size of the installer small yet still allowing to use the -Pacman package manager to initialize a full-fledged MSys2 environment +Pacman package manager to initialize a full-fledged MSYS2 environment plus Git for Windows' packages. The bootstrap script needs to force-install the packages because the net @@ -27,7 +27,7 @@ therefore refuse to overwrite the files from above-mentioned packages. To keep the development environment up-to-date, developers need to run update-core - # If core-packages are updated during that call you MUST restart MSys2 + # If core-packages are updated during that call you MUST restart MSYS2 pacman -Syu from time to time. @@ -37,7 +37,7 @@ from time to time. Core packages like the `msys2-runtime`, `bash` or `pacman` itself should be updated via the pacman `update-core` script. Because those core packages are linked to the `msys2-runtime` (and each other), and updating the runtime "in flight" results most -often in heap corruption as far as MSys2 is concerned. +often in heap corruption as far as MSYS2 is concerned. ## Alternative Method @@ -62,4 +62,4 @@ project when it was still based on MSys 1.x. At that time, MSys 1.x did not have a package manager, therefore the original net installer (ab-)used Git as a package manager. -Since the new net installer no longer needs to ship with Git (instead using Pacman to install all the packages (including the `mingw-w64-git` package) that are current at the time the net installer is launched), its versions are no longer tightly coupled to the Git version. \ No newline at end of file +Since the new net installer no longer needs to ship with Git (instead using Pacman to install all the packages (including the `mingw-w64-git` package) that are current at the time the net installer is launched), its versions are no longer tightly coupled to the Git version. From 1596099b8c0aa8274cd94c1d93c531f3ff413c77 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Fri, 29 Jan 2016 09:18:31 +0100 Subject: [PATCH 166/591] Copy-edit from https://github.com/msysgit/msysgit/wiki/Diagnosing-why-Git-is-so-slow --- Diagnosing-performance-issues.md | 39 ++++++++++++++++++++++++++++++++ 1 file changed, 39 insertions(+) create mode 100644 Diagnosing-performance-issues.md diff --git a/Diagnosing-performance-issues.md b/Diagnosing-performance-issues.md new file mode 100644 index 00000000000000..bf953df927124d --- /dev/null +++ b/Diagnosing-performance-issues.md @@ -0,0 +1,39 @@ +Under certain circumstances, Git can become very slow on Windows. Here are a couple of hints to figure out why. + +# Trace executions in the Bash startup + +When starting Git Bash is already slow, edit the file `/etc/profile` and insert a `set -x` somewhere at the top. This command will tell Bash to echo the commands it is executing so that you can find out which commands are slow and investigate more closely in that direction. + +# Activate Git's own tracing + +Git often executes subcommands, hence it is possible that you run a certain Git command but the tardiness stems from a *different* Git command. To find out which commands Git executes internally, set the environment variable `GIT_TRACE` like so: + +```bash +GIT_TRACE=1 git stash +``` + +# Redirecting output to a file + +Sometimes the output is too verbose – or the command-line window flashes and closes too quickly to read – to make direct diagnosing of the output practical. In this case, simply redirect the entire output of the Bash to a file, like so: + +```bash +exec > "$HOME"/Desktop/debug.txt 2>&1 +``` + +After diagnosing the problem, you *will* want to remove the redirection, otherwise you will not be able to interact normally with the Bash. + +# Enable the filesystem cache + +Windows' filesystem layer is inherently different from Linux' (for which Git's filesystem access is optimized). As a workaround, Git for Windows offers a filesystem cache which accelerates operations in many cases, after an initial "warm-up". This workaround can be activated in the installer, on the last wizard page, or you can activate the filesystem cache per-repository: + +```bash +git config core.fscache true +``` + +# Avoid inspecting large working trees' modification times + +When working with large working trees, Git's (frequent) checking whether files were modified since Git's internal index was last updated can lead to substantial lags. In such a case, it can make sense to switch off this check, but it comes at a price: it requires discipline on the developer's side to keep track which files were changed *and `git add` them explicitly for the next commit* (the output of `git status` will *no longer* identify modified files). You can disable the check per-repository thusly: + +```bash +git config core.ignoreStat true +``` \ No newline at end of file From c37acd4293581336a8950b3e3d67841609f4c49e Mon Sep 17 00:00:00 2001 From: Christian Brabandt Date: Wed, 3 Feb 2016 11:33:05 +0100 Subject: [PATCH 167/591] initial version --- Issue-reporting-guidelines.md | 6 ++---- 1 file changed, 2 insertions(+), 4 deletions(-) diff --git a/Issue-reporting-guidelines.md b/Issue-reporting-guidelines.md index 00b5b5a3d3b182..a2b093f3b0e966 100644 --- a/Issue-reporting-guidelines.md +++ b/Issue-reporting-guidelines.md @@ -1,9 +1,7 @@ -* Search the existing [open](https://github.com/git-for-windows/git/issues?q=is%3Aopen) and [closed](https://github.com/git-for-windows/git/issues?q=is%3Aclosed) issues. Maybe the bug was already reported? -* Include the output of git --version and the Windows version. In case the issue might depend on the server include its git version and OS version also. Of course, if you use a 32-bit OS or 32-bit Git on a 64-bit OS, you really want to mention that, too. +* Search the existing [open](https://github.com/vim-airline/vim-airline/issues?q=is%3Aopen) and [closed](https://github.com/vim-airline/vim-airline/issues?q=is%3Aclosed) issues. Maybe the bug was already reported? +* Mention your terminal (if you use the terminal version), vim version, font used. Also terminal related things such as tmux/screen, $TERM, or similar things should be mentioned * Describe your issue properly. If you spend 30 seconds throwing out a sloppy report, do expect that others will spend exactly the same amount on trying to resolve it. * Include a [Minimal, Complete, and Verifiable example](http://stackoverflow.com/help/mcve) using GitHub Markdown's `codeblock` delimiters. -* If your issue stems from a particular repository include its URL. If the repository is proprietary try to create a public test repository showing the same issue. * Be prepared to test fixes! * Be polite. You are asking highly competent software developers for help, for free, so you might want to avoid treating them as if they were a commodity or at your free disposal. -* An example for an outstanding report can be found [here](https://github.com/msysgit/msysgit/issues/206#issuecomment-44574988). You may want to imitate the level of detail. * For further inspiration, read reports that were resolved successfully, http://www.chiark.greenend.org.uk/~sgtatham/bugs.html, http://stackoverflow.com/questions/how-to-ask and http://whathaveyoutried.com/. \ No newline at end of file From c37d3fd5703e0d2f2779b730638497d3ef41a8ec Mon Sep 17 00:00:00 2001 From: Christian Brabandt Date: Wed, 3 Feb 2016 11:34:16 +0100 Subject: [PATCH 168/591] Revert 1596099b8c0aa8274cd94c1d93c531f3ff413c77...c37acd4293581336a8950b3e3d67841609f4c49e --- Issue-reporting-guidelines.md | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/Issue-reporting-guidelines.md b/Issue-reporting-guidelines.md index a2b093f3b0e966..00b5b5a3d3b182 100644 --- a/Issue-reporting-guidelines.md +++ b/Issue-reporting-guidelines.md @@ -1,7 +1,9 @@ -* Search the existing [open](https://github.com/vim-airline/vim-airline/issues?q=is%3Aopen) and [closed](https://github.com/vim-airline/vim-airline/issues?q=is%3Aclosed) issues. Maybe the bug was already reported? -* Mention your terminal (if you use the terminal version), vim version, font used. Also terminal related things such as tmux/screen, $TERM, or similar things should be mentioned +* Search the existing [open](https://github.com/git-for-windows/git/issues?q=is%3Aopen) and [closed](https://github.com/git-for-windows/git/issues?q=is%3Aclosed) issues. Maybe the bug was already reported? +* Include the output of git --version and the Windows version. In case the issue might depend on the server include its git version and OS version also. Of course, if you use a 32-bit OS or 32-bit Git on a 64-bit OS, you really want to mention that, too. * Describe your issue properly. If you spend 30 seconds throwing out a sloppy report, do expect that others will spend exactly the same amount on trying to resolve it. * Include a [Minimal, Complete, and Verifiable example](http://stackoverflow.com/help/mcve) using GitHub Markdown's `codeblock` delimiters. +* If your issue stems from a particular repository include its URL. If the repository is proprietary try to create a public test repository showing the same issue. * Be prepared to test fixes! * Be polite. You are asking highly competent software developers for help, for free, so you might want to avoid treating them as if they were a commodity or at your free disposal. +* An example for an outstanding report can be found [here](https://github.com/msysgit/msysgit/issues/206#issuecomment-44574988). You may want to imitate the level of detail. * For further inspiration, read reports that were resolved successfully, http://www.chiark.greenend.org.uk/~sgtatham/bugs.html, http://stackoverflow.com/questions/how-to-ask and http://whathaveyoutried.com/. \ No newline at end of file From 668bf497975c2ce3302c2afed301b6f4f7e1f4fc Mon Sep 17 00:00:00 2001 From: Todd Weed Partridge Date: Mon, 15 Feb 2016 10:36:41 -0500 Subject: [PATCH 169/591] Added manual method for `stat-ssh-agent.cmd` not present --- Auto-launching-ssh-agent-when-git-starts.md | 23 ++++++++++++++++++++- 1 file changed, 22 insertions(+), 1 deletion(-) diff --git a/Auto-launching-ssh-agent-when-git-starts.md b/Auto-launching-ssh-agent-when-git-starts.md index ee37766b4cdd29..13a30dd8271533 100644 --- a/Auto-launching-ssh-agent-when-git-starts.md +++ b/Auto-launching-ssh-agent-when-git-starts.md @@ -8,4 +8,25 @@ Run the ssh agent: This should work both in a `cmd` and `bash` shell and can be included in `~/.profile` or `~/.bashrc`. -The [Github instructions](https://help.github.com/articles/working-with-ssh-key-passphrases/#auto-launching-ssh-agent-on-msysgit) are still valid but not needed anymore. \ No newline at end of file +The [Github instructions](https://help.github.com/articles/working-with-ssh-key-passphrases/#auto-launching-ssh-agent-on-msysgit) are still valid but not needed anymore. + +## Manually + +To launch, put in `~/.profile` or `~/.bashrc`: + +```bash +# ssh-agent auto-launch (0 = agent running with key; 1 = w/o key; 2 = not run.) +agent_run_state=$(ssh-add -l >| /dev/null 2>&1; echo $?) +if [ $agent_run_state = 2 ]; then + eval $(ssh-agent -s) + ssh-add +elif [ $agent_run_state = 1 ]; then + ssh-add +fi +``` + +To close on shell exit, put in `~/.bash_logout`: + +```bash +ssh-agent -k +``` \ No newline at end of file From 0b365015f2125ea4f1f1661d2753820bf61920a9 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Tue, 16 Feb 2016 16:15:22 +0100 Subject: [PATCH 170/591] To debug Git in GDB, ASLR needs to be disabled, in addition to the `-O2` flag --- Debugging-Git.md | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/Debugging-Git.md b/Debugging-Git.md index 254ebbb2dacf59..3afe84fa8a1d4f 100644 --- a/Debugging-Git.md +++ b/Debugging-Git.md @@ -1,6 +1,11 @@ # Debugging Git using the GNU debugger (GDB) -First of all, Git's `.exe` files should be rebuilt with debugging information, and without optimization (because `gdb` has serious troubles single-stepping code compiled using `-O2` for some reason). To this end, [install the Git for Windows SDK](https://git-for-windows.github.io/#download-sdk), edit `/usr/src/git/Makefile` to remove the `-O2` from the `CFLAGS = -g -O2 -Wall` line and then run `make` in `/usr/src/git/`. +First of all, Git's `.exe` files should be rebuilt with debugging information, and without optimization (because `gdb` has serious troubles single-stepping code compiled using `-O2` for some reason). To this end: + +1. [install the Git for Windows SDK](https://git-for-windows.github.io/#download-sdk) +2. edit `/usr/src/git/Makefile` to remove the `-O2` from the `CFLAGS = -g -O2 -Wall` line, +3. edit `/usr/src/git/config.mak.uname` to remove the line `BASIC_LDFLAGS += -Wl,--dynamicbase`, and then +4. run `make` in `/usr/src/git/`. After that, you can run Git's executables in GDB like so: From 8064bb727f36cb85cf6f0a8159d2541518482272 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Wed, 17 Feb 2016 13:05:42 +0100 Subject: [PATCH 171/591] Some touchups to elicit better bug reports --- Issue-reporting-guidelines.md | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/Issue-reporting-guidelines.md b/Issue-reporting-guidelines.md index 00b5b5a3d3b182..c44e9204942fa3 100644 --- a/Issue-reporting-guidelines.md +++ b/Issue-reporting-guidelines.md @@ -1,6 +1,8 @@ * Search the existing [open](https://github.com/git-for-windows/git/issues?q=is%3Aopen) and [closed](https://github.com/git-for-windows/git/issues?q=is%3Aclosed) issues. Maybe the bug was already reported? -* Include the output of git --version and the Windows version. In case the issue might depend on the server include its git version and OS version also. Of course, if you use a 32-bit OS or 32-bit Git on a 64-bit OS, you really want to mention that, too. -* Describe your issue properly. If you spend 30 seconds throwing out a sloppy report, do expect that others will spend exactly the same amount on trying to resolve it. +* Include the output of git --version and the Windows version. In case the issue might depend on the server include its git version and Windows version also. Of course, if you use a 32-bit Windows or 32-bit Git on a 64-bit Windows, you really want to mention that, too. +* Mention what options you chose when installing Git for Windows, what console window you use (if any), anything that will make it easier to understand what exactly you tried. +* If your setup is different from "normal" setups in any way, it is a good idea to put specifics about that into your bug report, too. +* Describe your issue properly. If you spend 30 seconds throwing out a sloppy report, do expect that others will spend exactly the same amount on trying to resolve it. In contrast, if you write a complete and pleasantly informative bug report, you will almost certainly be rewarded by excellent help with your problem. * Include a [Minimal, Complete, and Verifiable example](http://stackoverflow.com/help/mcve) using GitHub Markdown's `codeblock` delimiters. * If your issue stems from a particular repository include its URL. If the repository is proprietary try to create a public test repository showing the same issue. * Be prepared to test fixes! From bee0ae0f735de71d28e17c53c13392442ded69a3 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Wed, 17 Feb 2016 17:09:11 +0100 Subject: [PATCH 172/591] We also need to install msys2-devel! --- Building-msys2-runtime.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Building-msys2-runtime.md b/Building-msys2-runtime.md index 8acad34e26d59b..66dc9362a9785b 100644 --- a/Building-msys2-runtime.md +++ b/Building-msys2-runtime.md @@ -6,7 +6,7 @@ 1. Open the *Git for Windows SDK* *MSys* shell by double clicking `msys2_shell.bat` in the install folder. (i.e. not the *MinGW 32-bit* nor the *MinGW 64-bit* one). -2. Install the MSYS2 Toolchain: `pacman -S base-devel`. +2. Install the MSYS2 Toolchain: `pacman -S msys2-devel base-devel`. 3. Initialize the local MSYS2-packages clone: `cd /usr/src/MSYS2-packages && git fetch origin && git checkout master`. From d159d7c13dc8eab058852777f2eb62e3a623fb64 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Fri, 4 Mar 2016 15:56:35 +0100 Subject: [PATCH 173/591] We require a certain format for the version... Actually InnoSetup... --- Making-an-installer.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Making-an-installer.md b/Making-an-installer.md index f860411324454f..5e0081145e9bd3 100644 --- a/Making-an-installer.md +++ b/Making-an-installer.md @@ -9,4 +9,4 @@ git checkout master ./installer/release.sh -test ``` -where `` is the Git version. \ No newline at end of file +where `` is the Git version (please note that the `` cannot contain dots after the numerical version: `2.7.2-hello-world` is okay while `2.7.2.hello.world` is not okay). \ No newline at end of file From dfe4627b3c4f3d56ef840eb88476d978c7276f22 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Mon, 7 Mar 2016 17:16:06 +0100 Subject: [PATCH 174/591] Distill a first version of this page from https://github.com/git/git/commit/df5218b4c --- The-difference-between-MINGW-and-MSYS2.md | 27 +++++++++++++++++++++++ 1 file changed, 27 insertions(+) create mode 100644 The-difference-between-MINGW-and-MSYS2.md diff --git a/The-difference-between-MINGW-and-MSYS2.md b/The-difference-between-MINGW-and-MSYS2.md new file mode 100644 index 00000000000000..e08ea7a39e2955 --- /dev/null +++ b/The-difference-between-MINGW-and-MSYS2.md @@ -0,0 +1,27 @@ +# tl;dr + +MINGW refers to executables that are compiled using the GNU C Compiler but target the Win32 API. MSYS2 refers to executables that are compiled (another) GNU C Compiler and make use of a POSIX emulation layer. + +# Background + +First of all, it needs to be noted that many parts of Git are not written in portable C; Git relies on a POSIX shell and Perl to be available instead. + +## Git for Windows 1.x (MINGW and MSys) + +To support the scripts, Git for Windows has to ship a minimal POSIX emulation layer with Bash and Perl thrown in, and when the Git for Windows effort started in August 2007, it used MSys, a stripped down version of Cygwin. Consequently, the original name of the project was "msysGit" (which, sadly, caused a *lot* of confusion because few Windows users know about MSys, and even less care). + +To compile the C code of Git for Windows, MSys was used, too: it sports two versions of the GNU C Compiler: one that links implicitly to the POSIX emulation layer, and another one that targets the plain Win32 API (with a few convenience functions thrown in). For performance reasons (the POSIX emulation layer puts a serious dent into execution speed), Git for Windows' executables are built using the latter, and therefore they are really just Win32 programs. To discern executables requiring the POSIX emulation layer from the ones that do not, the latter are called MinGW (Minimal GNU for Windows) when the former are called MSys executables. + +This reliance on MSys incurred challenges, too, though: some of our changes to the MSys runtime -- necessary to support Git for Windows better -- were not accepted upstream, so we had to maintain our own fork. Also, the MSys runtime was not developed further to support e.g. UTF-8 or 64-bit, and apart from lacking a package management system +until much later (when `mingw-get` was introduced), many packages provided by the MSys/MinGW project lag behind the respective source code versions, in particular Bash and OpenSSL. For a while, the Git for Windows project tried to remedy the situation by trying to build newer versions of those packages, but the situation quickly became untenable, +especially with problems like the Heartbleed bug requiring swift action that has nothing to do with developing Git for Windows further. + +## Git for Windows 2.x (MINGW and MSYS2) + +Happily, in the meantime [the MSYS2 project](https://msys2.github.io/) emerged, and was chosen to be the base of the Git for Windows 2.x. Just like MSys, MSYS2 is a stripped down version of [Cygwin](https://cygwin.com), but it is actively kept up-to-date with Cygwin's newest revisions. Thereby it already supports Unicode internally, and it also offers the 64-bit support that we yearned for since the beginning of the Git for Windows project. + +MSYS2 also ported the Pacman package management system from Arch Linux and uses it heavily. This brings the same convenience to which Linux users are used (from `yum` or `apt-get`), and to which MacOSX users are used (from Homebrew or MacPorts), or BSD users (from the Ports system), to MSYS2: a simple `pacman -Syu` will update all installed packages to the newest versions currently available. + +MSYS2 is also *very* active, typically providing package updates multiple times per week. + +It still required a two-month effort to bring everything to a state where Git's test suite passes, many more months until the first official Git for Windows 2.x was released, and a couple of patches still await their submission to the respective upstream projects. Yet without MSYS2, the modernization of Git for Windows would simply not have happened. \ No newline at end of file From 6f81c5d3d874b5a7eb92bc835873cee48be72422 Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Sat, 26 Mar 2016 14:27:20 +0000 Subject: [PATCH 175/591] Linked to further details about the regression test page (which falls off the regular page list) --- Building-Git.md | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/Building-Git.md b/Building-Git.md index 7f5021eb7f40ce..39a01d93aaa406 100644 --- a/Building-Git.md +++ b/Building-Git.md @@ -33,4 +33,11 @@ cd /usr/src/git/t /usr/bin/time prove -j 5 --state=failed,save ./t[0-9]*.sh ``` +## See also Regression Testing + +Single tests, block of tests, or the whole test suite can be run, as detailed in +[Running Git's regression-tests](https://github.com/git-for-windows/git/wiki/Running-Git's-regression-tests) + + +--- TODO: mention good practices to develop using Eclipse, MSVC From b4db60c2a6d1656666678c745705f03be74fd567 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Fri, 1 Apr 2016 15:13:35 +0200 Subject: [PATCH 176/591] Explain how to use GDB inside Emacs (courtesy of @jeffhost) --- Debugging-Git.md | 41 ++++++++++++++++++++++++++++++++++++++++- 1 file changed, 40 insertions(+), 1 deletion(-) diff --git a/Debugging-Git.md b/Debugging-Git.md index 3afe84fa8a1d4f..fc1cb68ff2b3ff 100644 --- a/Debugging-Git.md +++ b/Debugging-Git.md @@ -22,4 +22,43 @@ b error_builtin b die_builtin ``` -before calling `run` in `gdb` to stop execution at the appropriate time. \ No newline at end of file +before calling `run` in `gdb` to stop execution at the appropriate time. + +# Debugging with GDB in Emacs + +First, install `emacs` and run it: + +```sh +$ pacman -S mingw64/mingw-w64-x86_64-emacs +$ emacs +``` + +Then type: `ESC-x gdb RETURN` + +It should then prompt you to enter the name of an executable. Give it the full path to the actual executable (such as `C:\git-sdk-64\mingw64\libexec\git-core\git-test-dump-index.exe` or just `git.exe` if you want to debug a builtin). + +You should get the usual gdb startup banner. At the first prompt, type `pwd`. For some reason it starts up in the exe's directory rather than the CWD of the shell. So you can cd to the root of the repo you want to work with. + +For help, type `help`. + +Type `apropos word` to search for commands related to "word"... + +``` +Reading symbols from c:/git-sdk-64/mingw64/libexec/git-core/git-test-dump-index.exe...done. +(gdb) pwd +Working directory c:\git-sdk-64\mingw64\libexec\git-core. +(gdb) cd e:/testrepo +Working directory e:\testrepo. +(gdb) pwd +Working directory e:\testrepo. +(gdb) b main +Breakpoint 1 at 0x4018da: file test-dump-index.c, line 57. +(gdb) r +Starting program: c:\git-sdk-64\mingw64\libexec\git-core\git-test-dump-index.exe +[New Thread 13028.0x3a50] + +Breakpoint 1, 0x00000000004018da in main (argc=1, argv=0x6e0498) at test-dump-index.c:57 +57 int main(int ac, char **av) +``` + +You can then debug like normal (for gdb), but with a split screen and the source in the other panel. there are some toolbar helpers and you can set breakpoints using the left gutter. \ No newline at end of file From 23f5ff7bd46883fd1b6fb13ee0e096b6d02f2a1c Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Fri, 1 Apr 2016 15:16:12 +0200 Subject: [PATCH 177/591] Add screenshot of GDB inside Emacs (courtesy of @jeffhost) Signed-off-by: Johannes Schindelin --- Debugging-Git.md | 5 ++++- emacs-gdb.png | Bin 0 -> 46786 bytes 2 files changed, 4 insertions(+), 1 deletion(-) create mode 100644 emacs-gdb.png diff --git a/Debugging-Git.md b/Debugging-Git.md index fc1cb68ff2b3ff..ce4c7ef63c5ea7 100644 --- a/Debugging-Git.md +++ b/Debugging-Git.md @@ -61,4 +61,7 @@ Breakpoint 1, 0x00000000004018da in main (argc=1, argv=0x6e0498) at test-dump-in 57 int main(int ac, char **av) ``` -You can then debug like normal (for gdb), but with a split screen and the source in the other panel. there are some toolbar helpers and you can set breakpoints using the left gutter. \ No newline at end of file +You can then debug like normal (for gdb), but with a split screen and the source in the other panel. there are some toolbar helpers and you can set breakpoints using the left gutter. + +Screenshot: +![GDB in Emacs (screenshot)](https:emacs-png.png) diff --git a/emacs-gdb.png b/emacs-gdb.png new file mode 100644 index 0000000000000000000000000000000000000000..52b77c43cf87873ec8f7ba6f627d74be6fb4833a GIT binary patch literal 46786 zcmaI7WmKC@7d9HaK#R3N@!|yvl;Tn-?oiyNxH}1!&_aPyik0H-rMOE7?(SL$?vUb6 zPWrs>d)D)P>#XyG#oS3|X3w>+Ei-%W@b_x+Pw*)5006)fMFkm6002V~0619B~>K>fXZn6yAN2XXIwW015W^ep!4q^TCeL*D*&KQ zPf<4^QnT-27~)XV(yFC3KoNnrP&JsH)%~oryH9) zUlvo)ck^=Qccv*0-#Ej_>&P3>4`3|~W0+h)!>k|MzF@YulMu<1$WTeRA4!qF1}0*Q zVPi$r3{rWHN{gor4V0Aqf|T7rav=AEBHkw({Us$@g~i3iwh?r9n1d@JVF)Vq`*B|6 zdTYgm`ztd)ySj#lL+N|Y(<6;83T_Ph|@mHN>v@N2bqcH;CHJY2z_t&xW7%ur;jMWsd5n3N9y?C5F$j_@T zj1uV>epAx*CVoCX^xuDo=l=}T`nH$CeOIwew>91qKglHcdI##v`@E_J4tk~_^stJ7 z(e}q#2C<4SUrgQ59}A^ltgWLP=+vX49I zT4n#`+~boK=Q9$W3Fsnmy*PagLG#oTECgJzn1mFwnKU zcCS9hPfM2srqYN6bG#)F*8MvH0UZ`ghF{uEcb44G zvC^>_q7}-|V{LaD5hV`0rYEFb}@PotDWb$bO_M0oqT4s6W?f2SNehj73VzSz-ew>2S}V(VjGExn>f)ovaJh!nYK@Xj6P)anvxO?5+UM%m@$czlyOm5i z(}{x9ayVgC;`zBAGb1YYAFg(NUZOfyLayx0y6=-mQYzRE^g}iwYcFel@!DDaU9xz< z2ijG1GxEPuQ;1Xbd7U)YlUFHrQji+k@s2rsiN*{Q4x|MY2Q5qq3S5htAx(|4tBS2h znq|hNK)3BSx-;ml1y+dR)W3th38-z~qVc||?x*E(Ffc26du?0c4Hiz}H{$sR^@<3u z(Xo^x`hkn0cO4b@yHh1bomR;&P$I5|MsKH3Pk0b;Hg8X}u^9RC?^Fl9oOJxAYQT4# zfMICE$XwD)78Q+2+d|m>{`Vh~RzJmAt>q@4-G%dF^4)mdGk&+@H66Y0swKcXOL6(W$j%g*-G>h+g@fTIN?mM2HW2J#78SkZ~v4;H_icY^j0s{P9Yfa|1YWOm}> z_m!FPOsywLWChqZaJdo+alC*UOeX_HCc$Cqymz~nn_sqBP+vTb1k;^5Cixk@r$5bz z2p4o2kPzkQ#rmg9%c86JjuKnF_zKov9P3wauk7#XNZvAJevAuH51Owh-VZCkC<|6A z_xiQzSvI7a5$+KRJ6%hZ?al<|n{Ttl`)XO%jU;aSosWTk#h5Z^H`Q0sp>&GgSx@Y8 zWy2frWAD6DNRsRt6b}xo4-YN-h zj_%zetv3Omd$3Lo?sxx6@Vq4wWt*6UaG1A&GH=>uwkqP`l&35l=5DU?SLnjkebL*m zp3Xm>5}}wp^TcdDJviM=jM-Y(hS#x0Y?kWOe&2y-3yMUEmDBkru*^j-aEE{Kmjui*FjHar72^$YI=jok#%x#s(#)qT zie?q!u@fRM)5GW(=%nBy`7Ae92*~}%m7=jqa7R~-S`cUscn)1Hp@S~a&m8XzdNpYa zldjE?iYk`tX2f^?Lapw1h>bVYuja9Yje33<6yw-MNDSDJAoy4ic-lPxnV=N+OcKm^ zpY6~cJ$kVIY9#U0JU6gx7gw7mG?K2FP$Yju*R2^)gB2BhYJD1PsQe`~Pw{3- z#!kD~u~G5Q2aQ?bN2ne}J)#w4L(tWRN~1peDePBKk|cI~>>5{-Iup3=>_k!|lJ1WbEw{otHSq+yimrc9iAvng~^%6#r0EKz0`F ze)JWj{)Unh_*W`570N2R+N+izw_}$|2ZNlHv@NOU+KyJn%mR5N!*y>ObtgS*5`_B- z0cbuTFqYblZNJm<=ldc+{pSlRS9PqUe zkr-JR4>AO~F!N#COYVQqdP^HC_2q>j^tsC;4!u-PSAT*>(doD2WMfYyfUYJ`u6?ox z)y#be{n@nJIFc!5mY(WC@MA!!@@$$6{;F;87iGQjNs`DfUGbm2x_wCcm`2|Y;UmR} zkgsF@guZfrdc516Y(n!GrSO^PrC`@(V7~vQX;YBdqpv80Y=`IG`fp`?JDC6>HSxQ^ zqkniCJGm{zM5p_|pw_`}Dc>GNmTqUb6;wh}-g0M7v@n19F!8n?{9B6zwI1m;n(THp zTjQ58uT>N`^T`8+*0gxH{?0^$#qamz>E1|$S;1z{@RjAWI4sof9edP9D=6ltq#-zd z)iwu)%X&oh@QpjQL4&K@XVGd^BFshR>x`rdIo7fgVMhJl(zk4qr%!{AN)OObiZee5 zUGH%THM`qYZ>^jp)bA`LL%YS5uB)Y}mcxjeUv&}z`aL|cU0vuJ5`SI{mI4~0R)}Ny z4~cvZj%qWk9O=J}iJ}Lgml}pM|CWEvf?_~55=i@}~AyfbFfhE21xUDISt^4Z(obS)gCGp6)B+4DX zxm2mXzxI7NPXALZeuMFD{6l$~H@&A#!UOx*){DPZoWA9fQl;@4kC>IoZr(S3x;e@P z&%ksg384w6rWJkFnb6}pX1?3w(z(EHqs+ZD221Pa2$Pgvq~*}AVayIC@-hn!_f zKr9&~{JjnawaoILag;!0A!c7pt>Xi|>>x|dIh)EYL+08buRV_sTJ{ZMKRF3P zM)D#%jq!8>+wT+-I|R-JM;Sg$&wDwN_Mx2%+Zz&v**eKXL`ue4-OPzj+di}nVT7Ua zy5jfQ)12kLK4p?*e{3Bg)@-8?X-xY$o2XA0gPq&Oxkz(SrpDFzgFfe2p8Qbplcs^i zdP4;ZcTIYuLn&oa9{A!4;9_#1uWg=;8hc30?fLJaTkQs0$XmI7-PD@j@|9^I@I*d@ zwXq1kgf1j}l3bs#8E^%1W25uP&vtS_qsDdSb>%@SAf6j>E|W=q3YX|0e_Y^R_qOn7 z!f5sN9iyJq6q*sbFRjqyK9tZq>D$(D7J&J4*r^zxPU_9+%MAWjgkp`YzW~)>3y~6& z5mjq_IZ3H(c~fngXhuC4&Cxk(?*7)u=(->g@+tKp1PhWMNnO{c!9D}vFzW9I+WYKvE^KDOec98c$<}Yf zm&{+MJel_ibgRBUzJqeH)^`pPd0=SsVQY9hV!`su%MB}6HO|#OPlV2E$85GjYXPijDD?55{J*T>ne zppx?IAv^$zshz=5<|b;iT^G0o_W3VCqzW z3qsj!0c>XreE=a6{Ux}{Q?Jwy_(ul|h*cL9x0p9h@*qA=CQp@Ti zvso^!9yMmmXRCMT36Je4<%n)1NdkyQ`vRWL!-xFOk_%1jpYjEt`C0*vPd4WIhx~7n zZ;gwnz~}9c<{UF@eb3(NJ>p}Q;n6HRIe}Y7i$*gfG9EAen$fww$r+>W&R<(xW8bmDdf) zf~muHTjTpNM$4{n?+}s;|L4Q57Bi^L_LS47lh5jWR?xUIZPvdwy!^M~R0T7jt8|9nY zI*u(rIAgQS(|;w`^!bY>$9W&P|x8+yg(UPpH-0&$5z zwFr(0a?h8^loLVF@Ti`J2X*q{m9&ZNSgt}o63r|Ui;GZdi>-XGZ?V1DsCGm0rC~?h zQJ`6dm}dyKdd4tHU880#?{qT6pfQb79(p9Hw!9Oovo9*~mKxozef1p1EGo2%Uwb8T zKXwmKN`Fh?H{}$8>EK&&->I4AtHq=Om*#=G&Bu$SsugW}2FuHO)WsKD?@uNk?3o;T zC4*^-6$f?NE(q!S)cvNntF*A?9B&4jS3U~`WZ)Epr~2ww9Qd{mb$Wd4R)1GZI z(5B7YFZ_N9K}#&?kd0YB^V1_w_sJt}@!NSg_y81mooIGHBN)i&)amilnq`do27NfG z&fWH6hIKtsFU1*$%W)0?oN!9EOYP@G&v z^c9Z2&%zR#d25&bWuMbU+f&5v#?zoOY=ws}1IxZr53(<<-SWL|g$jFh;w{mP$2=6nkmC)3c2h%Q2FEI*++&a6+JN@oRLS`?(QKqCZ50ez^2S+ ztV%`wM$g~phaAlWZ2@VXzrC)>T`i6@A1t6$1@n`*X-ewxW-~Mqu)cW~!awz8O(vb< zJ=QZe6;VBQdQlF&_lg?J439&&Fo#P94DnU5;^$@orPyf-ZVc_=kNJh|vf(w3IXAV2 zvck9+YF2jS!19Tpy~|Ra-~*?@DKDWRBfNuO;hstMI4lJJ6Y)om$etx(ocz|SwaIUe(G$BCPtzX5)T^qW z&>plZnpg<;YVpgXdx*LLChY5*IHdqU8*pypWQq12wxPYAB$z#HYf;FdDO>z>KX%I$u@5x&j9L7I5u*k@pFMP7 zl?3?3s6dZq50gld%N16JX^XqA@qn?A4#m37CK`YdS|bW|qYU7d#Q-JQpbt%+KWBdV z1D6msom%2T&7{n5zN6oH)bZ?)L$J%nwDzcp98V(Lf)m79VW`KySzDx4WX&C%dFo0E ztty;pYW%HL;UuPkCt?Cg^-b}L1X?!Pgzg98;QXCsx2E$RXwJCs(n_NTn%%KEZ~;!YO^D6(rd=H z5rGGPs9l&Z8^*YBw3?-i{R@%`bRhhru-ORIOpa}yf@It14vkgy!$Lo~`O>RO0}acC z-KORR<2*hShtuA)k9emflP)DplP=`*(=6r-k)#{{u=NwhM|%{J|Hlm{--W{?*fxQL zvTFImv-!O4t@!MtOvdQ=g&N-34F$FUlBTVvJ--6*6K#gVGAiTGo+>h5wu1|Hy;5jL z8bLiljz6buBr~n9&q__>`M?@O{NviZnz4&=^_Qx#CV}{Qjy0)MmxMR8O!D5aQ>Ke& zf9Z1}dMIM00UobbTK|n6mC{kO4>5J!QdD`H`2E!{&B0y4!svLudc!;2aKONI}PWW&(|^k z(q-CyR1L=I-Xks`SURo(x6A>;Onp~-i)2R39$b)tFyZ>=l zq^j+dq1XL)z1+!~bvS+skKX-^AsbYrpWzby)7DFR6wzL!1NSB3N<-}cO>rtv(^lcF zH}D=EGuG|uTi*m4M;Do&VovGn+Wb6ttOfxr_`oNB!L1WNY+?yKoUK_XO{zZ<&4ZCH z{em3zX7XsH0!1=h5Flhm39+7Sl)vawLk%N*)h^Su%*5B(fig4h+hkvyVQp1sO+J$d z5YvgmEBhbqS+$p~+Fvd>mV+O)(Xy#P_fKwSYL!=O6*bC8dAUp@EsS*ED2_|TMy2p0 z%T1b|n{v)Bugyk~mwPl;)+&H9XEo0*EHB~ih}CUldn&t#$fYXJuj4K-@^+1TS2I#} zv(^DzPXc{b++^4NtcjVl_QvZ z{z0EN33zb-NCK628q@dge4PBiI)2oG_`R*Pv{Ou|M)TJ)(>7{&&9X3A`?(5CPMgwA zi>u3(PAN0S-6=k3^}fH^Ag7iP>JR$Ic-sgHY2LhkZ&__Gznj>)*Q2*SvF|yA1NR4B zH~Dw-3#`mvDqhUQ-$?n8nLHr6&9zO#iQsGykvV zKBfXMfw$L~Tvi`3Gk{{-*s9PBy;*AG{Q%+hXpPiK4JH@Ir=(eO@0#)fy;XhZ(ZVKVWLQx7r_bkSxl4Y5w)x_bmp$e_S_;{FC@EAMmittkP(07IyjB zkpp_;DR3YCQ^jHjk$Z#Yay1^Kr=oQU#T-)u{obMhY5reVnD9{vndmG1i)QnM55jG4 zQtzqBUiq6<*?+;pCwpaSa^eH>t-J|_BSD!DX2{ib)vs3;ps{(nFL6B~ZMb2ng>UBbl{D>v5OUJUAy}Jb6wGGw1ZyiB zvCmTeM~8C=k!hC`=XJXscwFCl8ok_b-YanvCvjbkJRJ$Vnns>P7Pnq4N+2WSr&04% z4IVtWo)*hQ&VR!o3VDVnNGaap5wh8GC;QbRVjo@*A~mf}4Z@!jKr8hyqOxW`BMT42jWuiO3B2c+)-qWPwuHSlo_QSD3eZG!4ph zijlq2XKCp2x#U0|5LW($vP=0J2m}C_PyJY5Vywn74)9 zzxYD-BZ1v9hH1-Ese zcEa)veI&@Qq2;s>zYMRn<+KYwC+3mjZa9vDrVMFU73DYa9mk!JGLq`~o2=YgQy;4t zucGec+T)Si7?JC!y4@5P5-~k%xDQ`doe6+tFt$0fly*5wl>Qky;Ooi_4Zxhe%Ljy5 ze#?ph_{bCFg9Avy`vL-dEP5U9Bj~sy006LbR(6R#c?V;NWq;}d3(`_Lbo@jVkKWYZ zQkHL!uiTwADVx0W)231fTU+nv+Da4W&*3c&0Ms1ZjDK2wD^sI`&Tel}?~pt;4NUvB zBEy^(${P1mEw(}jKWDi>9W%rxTdqK{TvC(qrJbb1S+NB^POqPbnCT~t3ASZ67Z^sF zR2aKt?_QV`zGPr&l>#argViLKoi_kOC84}a7-TK>#Qjk}>9y7<0#m*O`zAS$>hz!VJt_-Dx< z|5-iHGA9~Jk0|99ee!^XR~lwONdV?0+G|VK-=*3tTJl1EY>_;+(PZHv*TrY&+CDwq z4CvOBoBlHYt$uGWNFYv=R*kQvBu!OIu#)@DbaEwqm6+{yT0J{IT-$}8)G>~RNH0WZ z=S!*exwBFDX3D4tfel{(6z~z_{V;;BWk*9K(H~#t9U8+A;hV8oHB4dW>=ikr5N5^i zX&q5A;!%bEnc;&7W>b9Y_+od?nE=Kbi_ls&osuX*-=3D~SxxD}y;F;Jjz}J+Dj*u* z7J#rt18AWg698V5F03tC02fJjOy;iTPdAtRFU4a8Z8L|q=*C;;4@~^hMfsP0RHh7i zbG01RS@51kslhu>pv|Yu%QI+z3pt}^qY?N_N5I8}(?wmE=vQN7)1hTk&SleA%lTFK zp4-%DRPSTf2aSI57XAdaoLL8%DQS?P?n@9ZkD>z#(AUy~ZV`az67fD^w+Jy^cwGqU zQAqgLb$So^Tcu%`Wk1a38Te`v=XW40AGqfp1fVAMk-+~SAIHcLbsorcQ}@Z)J_kvG z-Smv+Or4QV|K&ert^$co4O>`%Ic(=+m(yFsR`t9^Bj0Q(wVy%6CaRC|{F=@}mtMEb zP8r6@+kSc$bU>Ti9|#!=5h4Ttpp{LD*l^Boyv*?mOm>;R{B>a}2Aj|Efg3a{*wzUk zzT;zpl^0wZ%VtuQp*L>@rnl>70zmYZ-VG~@6PHt(Do0Oi4y!7B)WZeK^pVmA$S@w< zvlayR_p2gW56)fwYei@%6R_0^6Fvk{blL-MM^mUrnAY``PYXP9Ce8;IuXmCQb)+#( zWMi9iZu%6?jyy`gG@Q9!YM@gstLlH1C_1r0X?)$nYa2FG<$pE=bHXiA=G%fP?MCad zdrzygZ#XM@gN%J?NZ(L$=lvAO|9Od9aHzYMzGD|=893?jCKR`TTUTDWEV|S(AEKlK zS#8A zvG&XBxiM2eS8|i(k=jb$SRfj!Pn^Vp?{`v(@M?K#fZ7I!i(u!)r94iKdI4u>d{h6! z^!SS5Eo`*1z;ZK7fpfXhKi3P>cZB&e*ZtLF5tl$28rIn*b)?r*=NKX-sC1;<5cos5 z>U8~PLDaMSrY}1ol<}(CTq;75>m%F7y);t8b!jOSI1vs%jR*5sH+|GC@KVpk-AH*^ z4x|?nccce>PMV_)Mk#N9y?Ebhk^FeS<-Ipeu?}L`odNzAIJL zQM&2_0P@2(KCI+8LPU0tt7acfILZ-EXFZQKHFKNg=8Mu7)g)3iOJuM3F1fiE9BJ(k zrhJkoCUsaG)x%~l(s&^maC) zTTVM5^)|~8_-`2a0TLoxFNi3tJ^?3O1D^-l=EQqS&c^wheZPHj=wtJ&m-9O$khi+J zpsXTBRYr660F)5pT~u6ux04=EA-kTyb>YlGR$IDme_4CqQqi*KV+e+tc@;;6!U)5u zC)g=wwik?RJ@$k5BW^sq;QgwX_RWFHF70pN#S!psam9h-s8IbTMd>cfLhIJnB}zRT zACm#-{XL%M_)-G#QTU(}_I1V}W_&F|cZ6ALyXIMKtL9^PJ##~p6Yf;+aHr9%?jRt;B+SK&@NKTCzd;OQM`T;k?$wdCueF-;Y&^Ggs-@uSOf5){U7rT5b2~%O8lENS=TSN!_117C-QB3p zdpaesTBD^06QHlmzkGNF_CIe5Caap!&qbcIk@O)U&cr4A<+D3Nc9)8<=Z-;YHktWF znM+|BQ|W}wlnxnJSe5{SNB=NUN_aV>26eekPTHt>aR4zovJv!SITv-24kwRu+48ORhVsPW!J`~NsfK%NK!#>w)a+zS?I|pyQ0% zmdmdE`ivr}F+wa@eP^O&eAmN3K<4buj&AM20)PDq))3fNx|KT_E>}OX^+Tw#B$Hus zKWRpAyR@}scdx)w88g*gY+8CEtEyFz8Oa%|ZHhEm__BPJ10rU5&^yxkCjKZpX4e+4 zthEO+;W7rl6{7yN^se_f`r+Um-1p_}&+Bxrcq5Y3{>rxc4~;o&i|%v0_ot$ijE%OD z>zbqfYaL(*U8(X{-k0r-O)jqjj6Q#PdfP-;5|yNvzHs@3!ubcAs!-7IXMgxNu<`-E zG*=_o$x!7^8?1vmDHEEp{y=SH8zwXF<6z<%W@AJjQ0O7B3EpxM=!E*Gg`-gk|OAkzVPF3&OLq!lZ6mz1db-@`Pc zKxJl62v+F<0H-iU7-Uuq;cXk&)T;uA&^S=5S>LH!i?x&4hlA2Ql|FshJZ!#9P{s~T z!g%U#p}{~?#{K1+-gP8E+3kLCL4D!LO~Zo@1#)MU;4D3?D*EdF;LpAp@h{~F|BKA$ z4hxkY&f|*Tz~CoK;d#OKq*4aR`g+ISt}MjPIzmbQ7KpkbwO>uMXlTSfdSMvn&|HnE zcTP?(pkc^u#I3!&bAOSSon={0vvQNz_w*JhM#xVP<}f>9edk>aZe3H!3*BNS0$1a8nfK)oe8{1Ms~8m2_7CH;d-Nr z@|zjR8y28hMZ@m|-Dh@MM|mE3e}kF%{)=TaK!FsBr#+XpY?XPJjCuX#p`@+yD~M!8 zH4Zj=UaWXN-7>Umju$;6jm?7)j^1wl3W)ypHzN_fxi^3-Nc~Mh>L%|>H6f0N zuKZOZKc0CA8{<3%LHdhlR1t4W0=8i7U=^Ak1H{mmOCGE{{`W^A=ko(5bloz;IK^32#~w5vcI0PfdR0XON}^FBBR%O-8kCqx|+<11saaPJ2^&AtUtZ2_UMir z19CC|4-@wNB#L6{nWvX{cD?O#Z>Xah#$GypuFJ!RXbCTex3G6V6l_{OexfFSXhg#% zM3;8}(VNP-G1SvegT&ab$J`LzS{%l>JeG|0Xf-^P*WO!yp(iLVDx6BhD0TMa4%m}wX z=QNN5Ch?bl zDn*%VVOlRZYcjm=qB(Bb0Aw?40fzS`=qji(|5EhunCx5Ao1|06UtCnN*7`HZu6J)Z~rUd>&!WN8b9X* zT!$c}B0VbiQsi}vXkhIa8z>|LO0@({2Gq zV&A0kcRw?H33OXs-G1rt8+vsW<|?LE zoGJeB2WIf*S#vx&Yu>wD?@}6)uW8;+^ZRbe`1VG05|?hYh>YABTM7TPT=H%qcCF@I z!}F$boQ@u-@|HOrhaxIl_(+Tj5U4DDHRkxJU2y5r6LC9|`{8`ow!wHM7}3}Pn{@@Z zm5-X@et*LayOP#h^QWBo{T>_e{B77*Q2Fv@`mL4k*+nX$=IXM4^a%%jh@Nc!$$|9c zX;r}6AFg6v67d|DUtmXPbbjA-737bO(E%!y|4LYd^qc*6p@E9!qZ!A%1up4emN%>M zqxx5P$}Y_v=!L%Lg?Bf;7o6jQJEU#58NMl|hu-hNpt~LaJ42}WPx9Ndl$BDBJFdB4 z$3Vch&%xbLTZzE1giG%bi!=_T_9oYa`?Z!~{z+-|OTimlKh-glTi#hTSuQzGh>c#k)3@G8V)%r=xzg{C20j z$odjKUfkM3h8RD+xzrFFILm~v>?y3a$e)XtDSC9)HHnv5<@g4S8ee>af~ zCM14~+FSI;b~Y#{{6zy(Cz^eNHpk{80cE3Hae9OSpl1DNU+q@mQy+1QIPy=1<4i7E z`Av(eov~-f?-#eY^3OhyIEeJvc$B`bly;3N`a|0as!QYER=%b%mMXvL*J(b3wr${Y0z!1KBKaGtQiwJFM<4nGEzz!Q0aT{OONet z?nzNIn6`ZJjhuc9ewr~|*Ey<|MX)^j=H^2PS4tNepa*B|Z{mysV0W4aR<$+oAd=F` zmggs7(oA;Iez~&*uO@se=SmWH0`tFdnT3;g=yjP+_=~%lJpNeZ(RZg7OoPe>@n>5N z5rq+dU@w$g4)V#nr3}#F_oL!WdIK-_I2*G-*K1AB0dZLW+CdS3@3~rSwp)6Cfohm9 zYbgdsE2um;xxWV>rprl;_k$6;^~Q%F6L%V-k8$hf$7{&hRTlb#%*G}+}4%PORm~7r}-tQIC zdJori@U#+$yr+niGTeGuWBC5lgO*HgR<6erovQ9`AyUVAhLd@xO1uH>`2lGIM%tp} z*ZNyYm-uCew46Q?{t9Ppllc@ai}QI$W$wfpLfwqWq+T*7^nZx)kFEWyiOOypm4}10 zFaaN*vi69QFWXeZx4~7_$%-_2toxVmUDvBTK%kJ;?ZG#K zG>RGbA zJlMV-`Jk5|`jt1q)4OenydYLVnX9?)t%)HS4;(+X|DMKDv4$jd)uz(U48c9QX8`T7 znWS@`9Y_@kn52v^l_<*-&m?Df128xGkMmeL#Y08e=dR7X@J<-BS&TD8Zx$jkySEQL z@bMjwF_~IC;+H`VvqKV{5A_>c9QOHBZ`9@+l@RTUAM!KCj1D?3VSuDZmXVHkL|~};RTt730bqa)3a~>cIEiDlcirz59Ag4wGUF`njuLo;4~h@ zSb0IszTEBTP?N(P`HB^MA0-g`zWBBYE3@{MWckxy<(7v#pSM#&%yaHn?gi{^b(67ZnXPoe1sim?e20_*>7eE z&Pn{Dv7Fg;U3`BY7k8OSYFR5}^`SP0VBDh}b&QBkK#I6|cyQX@ z2X7BrP&55jx)(GhMjh=5{_D8z^_I^p;>O%ZA{C;piy#nwsZA}A92xbXr+lr?a z^D{S_9a(H=z^cpL6EiIq*HU$VW~CIU&}7dRAi=8~=q(J%+16@X6SsH~B2ARopR~L2 z0R(OO>n4c(;Lo(h0i~k>>bhL_$M_tNj{4$_w%0Tc#vMZ_xpp&u#nwH-r6U(vh!y%U zm@uYW!OdQowxq1jQ%zgT_^K=ETj*mwedlrFY=q_g4I2Q8jj$DDrrwl6Dxd@A=y;aF zSF2&=Izp)?Zp^PuGg_NlVa=m;7ybIT{FEZyqH9jTEu~aR#j&_Ezl)8K`ER=R5MzjG zeKYVHU3o-C%}8-r%E;ijznZsI^1Sq}zna2;F_p=FK`#Y3^Jjx1Ii>LnGVd9;a&oC7 z=*@Ss%(L}`xep^j=`|%*kVTB5od&I#ts0eF$?`;QH(_m7!kzdV7w<=onPW56P2}I= zvQ><{hl)!4^L8=F&oa#y@vPZnqRRHJb!?^9I!_aeIG3u)91`!r4{z#Em|B0bE{IG| zSLV$oXZB>9>{lnGUQj7emEQIxaB6E@)}9L=!w(o2LAGP+ta&dwcPJ5GI6sS}e5B^` zN>DgRaz7(J{&peKExAx>+@g}>6fHigqzYy%)O$0+A(o#54*F4RelE&Ty33O#u+Fo- zNvvVs$A2C-rrJ)R_q56*=v(jrjDp-Ke{PN(^4kuxtNdp!M?jvvqLX3zRy#$MmCl5v zCVe*NB**y=)5fpIjT_R-35Vn`IZ+WeTd((?b}JrQz3BRIJcJ2aFAP9QLeS@4NB{YhFX0uu^Y2F*T#taLqE&L&cN}Ora$Vx)#_ayQ70FSKgtuPy zA`b&^mxUcHNDJ9srSyT?` zk9YlkY&FT3U?s#A2tMa%y@R%1j=}@a<0Zgbfj--d(eSI8Sv@mkuSA6iN?eM%fTMw7 z{e%X&2z;P;!Z^v4lyNRI>Spc@DRlRyetUMw;aQ4~Dc{`j{w47NM9S4Xa9-{+6( zZd*&OHDB0q$P3balw!J>kfszA-Yb%+dCm^P1=hSD=@V+SajTBeuxXDRvp_T<9rlIvS+Sg9dJ*!h3-F)vyu*oO}o9M|Pj@5u@ zbaNIma}1gB-|}l{lJg;|{Mr(%v+#`Q05B&~nw(Cp;qjtB`@DnE#Xo9qa)x{d0NKV> zo3$uqKz!y57}AQ8FaG}6fz&y%nw@k+A>0|hDiyyHDtZ-3xE1ezj1JX5jOvspvY%sa z9A`Fk_GAH81ic*7*KpXTj?;6N`Yijqj9w;r`X~2-mKq5TOE=(K=Eaa2VJprKkwZ9- z2ApQKMYm>>ssG?CD<1={w>pc%k}0Et$(o#V6k9co4!XTUo$tS`_;} zf{%);R;XH_+LP=JD_snzwrm%@EJ2Gb@R6mJGZdim!=*iHl0q*3$y)atKk!PpPriDH z^+rlMZE_yUjI!Zc_)TXy)A;Yw&rS3nq#}EXvdXi`tJp<2V zzG=BYZCD9*bd)R46#lUDEwy=fk=BIE|0K9PigN7MtAstZ^v&ruTzuGlfDc9+h&`{huWV&rJb)nlgvt(hlx^<{C3 z4R=O9vV)0nDC(Ed^gdj+ppC_zx2tVCmK!VxL;ex-a>aKRj|)Q!{$A(el^>eF>vaDX$^i!-C-H$wuUqO!HQ)bN#)UGQ ze!f}V8ax^!iuWOXs3ubgi;EFf;g7Yt+BIz~R&;Y5uO~p*j!rlGrE_tF`0kV&C23HH z;qbeHc^GbvE636~&KO@yT_c*#GfjLUVu0w%pLUn08vp}%!Y}IvXK(Go2%8sL%NiX1 zAMfnf>U7+c*j$V_BujI}0iF7E2R)yt{fJpn)tt~GOjJ3iOR@sB$3*|zWP101HG`fX zBme-fO)V;Jr`!kufF7(Mn(Cxs6I|4>=Rms)>b=q7hrr~EQX2h6S`rEx*#{y ztFUI^TUeutFCus8j+<8u?>Bk*>`eJX%}zD8xRl(R`dw6`(poq70k2VQ*cK0HXj60?*SCNLIQWzv_^v(7$4I>Psqw3~b~3^W zy=VY_AT7$$R-XS$4|e##>TXs;yS9_fI};O)P~#WH0imdBj8P%;95^S|PB<{tbek7q zG9=W-nWy5>61#TCs57ZbfqEO%!k_E1_ZSEJj-Fdy==}@7(3i9~?G@ z)=fLJkCN5fdXlsZT4#bSZ7Y|AxPkm zuTK_h%-y@BxPR1vg}Nj$L55nTIp2#pGyn@)5KZv*Jlbo&fp#vjo=zn9WJ@guhQzm} zcH0J@3>pAqA<4lXG12xtBlU(X}1p%fV%F&N)AbL1nKRP*4*nDOW5moE{vNlFf6HSI;}uCZ(sUt1Pj$p3F+qM`9DdpofDo+8AV03t09^BQMC#pXID#;B#JvRQCNSJ zYrEU=ApHq5+)_S77>nPO`K^mBcw-*p{4g`@C1iO(+{-QN&Y)ELG2MY-g6BglFBirCL)lvgRPpZpqDv8wmPS&P z5+nra5|Hlh?(T&&64G7LqICD7Q@VT6NJuTZW5F5xz3A|DaHu zNm0IbCr{_YdArC8%;~vgCyCUkBU*JlY7KjdT6Dfqh4cdBjBY;`hZ4e#RO=1~)BF#l zrcc2kw*9o7IMs1m2f6!k70?QQLKTUdD@K-4Z1~@?uiYBK)~2eIQUrv7SkaoB!#v0|7|aVi>mZiZX1}dNP30 z>c)Iw$AsE~-!n>E0gOnYU*uee2de^yyXsmTeTl%r{<#&P`vW&){8d3m=dCQWW)u4i zQd5%oE+Pf5fH<=OyvBHNMB2 z1s0{n#@;&V5GlRn7w@gNeLbe@rb-GvWz;aX%*xyBBDo*v%`n-SZ3f#Ei5@($Z5|1?2PJv8_u=Wxx4>)5C#O z>t|a$UuMY=kSl=Kctxi{0V=43W6{APp7nO=T}tl^vx0(6Zvh<*ihA)cVeSu*(e+<4 zlCVGlYXjW!elmLD1=6P2JsRl85JV{Oydux0Dq76Xved z^TzA3Af}6b!X1R){d57)1ERWWMQxJXhFm!+SSO7{ff@M1bKOy}kM!rd_^d>b-nl~6 zEj_7(%BzMlt5Wy%LK3R2#{1&+jy!8o^4s|7$bDkp&&9rA5_?8|6p=2@>z{^wyYIaG z`sS;IvMpm25Nk_bBByL(m<$N6GaJ^%^hQ_Y&7618-Nc+zUwuTx*)BR~(^&O!t&o3~ z_K7ZDwr(|3l!$RmFwRnU6(wLY^>9%%nA4IykJm! zfBTw*0hPz9XMkj#+X1~agUVsj3OcK875@C>>##+>#_WOqtOAr!>D5a0wGB!uwQJm z|MUa5hBl0fW4QXrMzZl%w=4wGmYFN+PX!b>qU zmI%>-N$4^LH@=f!pyse1?9Uy#>Gvs_X1`Tm;9qq{NaJ}OW%bIqoI>HK%p%=4tdoXp zx~@}TVLs6K!a1vzY?_NSk*&RI_R%U0e)=y{^gA)ElUBSK(N{)pudy-d`oxPmYlZom zxRGrl{*IVo0fi#|dI8UcTH?%=lJKi*u@p{3D|Mx1WsBS%<~}iKmBj@O9Ns{FaZ}l7 zH(-Zd0Sz$_S(Xtr8azme(|(@h1WEA8EO^4ui_GgU*cxZu4kI!Yj(Y$J++P$^kINq# zqjHoA=5&EKlp9J)$KHb4CCA=E$M=l-ksDf)gEwl5F2SZ7JJHd~H&3_?_bvRCW%CVA z3;j^QPlKsuV`lRmauEr?ozTmA-)}6pGt5xPXEOrKD;Ex!xUA%@By=S>UT682V8ntS z1r-7hrmcj^ZsOHn?=uv9UNRlLG5o9Fdh{P&A%y@|3ABc67n8wIi89k zxI>Wr`l2=0-jHI3=N0OKI~4)Lin(Sc#wIzX!A2c3Po0oH9cH^83KkcUOg_98Wrs_< z6PE&q=Ya6%q$#=;z3$g?)%@@;tu{83e7+XkTaJ_1yoyB~QCUa7w_<#DGV+A?xm|RQ z+G3?}mREf|RqFD38wf0{HA)ZSU6JMYuU*tyN2@L*u;>}gjr7-W)#A1;bJr~kBenfJ z$$ZQ?YOCwYUb)^qC;&x9Ojnhg>Q%~IEu{PNVZJU)Av-y3c&(yWc2huidwe?YMygobJ+uvh+=tK1}`Yn&f z8{?f*g2CJFpSKdbH(-%Z)g}U4cJBVoECS0um1P+SU<$G$hy}?n)NZD9)J=olah+Ef zsHb7YuN1N@9SXmXdjEWl!CX2)HyMSE&p9p34b5&mld9cTy$lOk3Vc3hqUxe5za*<6 za*=tTKWj00IPIM@ZOe%4K2LaB!oT!t^ssu}(()x|Fgk0>YfAi*jB{81d5g+2yYK$D zky`u7hsNIr?{_V-rfOn3=GO}Dx9BGb*{SJAILU;WEPG)-j>ct9)y%>}vi%p~(-4h@ zggN9wDGm3ZWhn?en8j!vkyyYZX zJOVjMFh#mz1^iJGh(GrSEL5DomZT6hG-Z#_v$f4EeD+Ug_YSdk8z$5?*b3dV}sE!ogTr=ljzX%;IjdKPUZowrg!=m$BELy}LX@lpRq0{(ZC@ z{TtAvp=)QcO$hiov8;z})SAr*L}1fYc~;x`R`@Uw1Uk!w+uHDbAVJ>At2eH9WFaIW zcA`kR{#c=|J#*i98%1$&7TBK#7LiH^==xR*V}c9M&2lIB776UH}SX43MV+GCsXW1)pAv zH#auQGM{ehE`4IAte#AlGdB9V>>&LRbMXX(DZQ|ufvR}Naq<7|AWWNwiU&O%QN}Y1cuOi8Vov-Z5SP|KM-&@t^kY^|Igha#FviFI3?SYxbZil=# zmC!ajL%4kz{zG4(0_RKZH~CLd{K-5_Wj$2+aq^UTV$0VKi;IH(bP&+w&cBVS?!Ni> zOc14*VngeB6EAcWD9!RD4;HB<+2*?M$kN?jXpnl4P`>@vhmj)d`R=I8=dO};(2VqA z2&p4VXBHXa3OuGaN9=%z-|R7K{bv&~#>&GU)#p5QrAN*2JuXHqubeAssI7}F{Vd!^ z;?5Zp_Sp_g?B|4V&i0`=9WNKew*nF@?-g(dRSyyqk>7N5{OK@*Q-!VDR0_PvM(Nzu z=8c$Tj>2**aO6rn*5|eRWdN56?u=_p=|^C1=;i6${KEx{T<(YpU_~qx8vTa*zL)Tx z*7z4mP8pJb{wzjtf~HTm82G8Rzv%UMn-_jrGPe)!C=nPK+cCcQoa^zij5%OE&hyuJqPl6JVz#308jjQ0rq? z(59<~*18#lNu*0ABi+a3qakj?K7d7;#o(PeJa?jxc?Hc@pUF}8g_;0_l-64ONJjqk z^CHc*4I}wrxH895)ZusN-Cz>qY&xc%AcT&}wYFqnu?%TJ@ z(wa@`;q2;~w#Zu722xKZIrKa*F{RE!pn@KeHyNHkPYM~8P}aWmgR7^*0=`N7snEcO z_=3=uC0hK7{{t~$O1QGcBU?G4MIy8?C6%NMUz5I+=N*}8O$6AOGBBG4cpme8q8hI3 zQJGTs8q~}-sM6LleBexMyi}zCu_fFqjyaBVXRkz&=Rf;UM62aSKh?egulU)yTh>+6VX?PwIn<+(9_MySEdJU}zhp#{c5U{d9{|}#xQ~T(! zD{1?tsq##1J~8Z@br{L`>_{CD7)r-v?1=K^OoDE>8NY>Aj#$O|T&?@BF8aO}*_{4y z^khH=&+O#Zq{idmu!-_4io}{W0R5}*)xK777Bs=P`cM8BkYA+&7FZz6_N1wjSSJJ) zk8}Al-9+O+#8g)jrM4OKr;t=YMs2)dK*s%g9qK;M6-~%HDg=<&CqR%B3L`z(l`Kni zQ=m50;~rl=k!0<5Gd9f*&Zg^jqp<+RdBV-uw1AA_A^PhF9A1KHbIJ#-Hr=#sOBMb`g86erl-mtE0UfJR<$@6E`zQc)J>R@p%rOfT*QG7P;YDVp6Gw z$$gvgFCBUHKT=c-`AT&z`_zKbK!9@Jm`_gg^}vr1{&XT!e0Hh&7FsAE`B`M|^bZhm z=&~BDOyh?I?Ho0g-AIsHebn#gY%vtoo-#0Z?IT9EK4l0Oc$HdL@H9H~H06gwe0t~5w( zGG>P4F!^2&d6RgYwTGvoO}pY|d_RX>D+|rxclPT%u!o5IQ(8kb)UmXb;@B}?FJt#0 zHx(FrtDUvkGSooHpCbtpMriPk$aP#YC`>|}w)`U8hl2@L-gW!9R*qg}kkdEHr5VuT zxxE8*y+!5~SVzsl7T9vZf0i2hL9_6CTX|6mcIm{p#1|129Xb>sO13+}F#SWF-$OKg z*ma~E4{}hskMkpLmip5W@lBRqEn}EtV1WjiEhE1jiLE7}30ksf(yLv$-iuj)^f8~2 z=}xomPze-Vp6IZsqE+bZCiMhwzJp!c)Uv!v(rVkTH52@PfZJGPjp2TO_iN}ms0(_J zj0ev1$L(n@L^gP4BM5}~+Ocs0mVzHc$&EnrYj)X*8qoTHi7$t+I4wPUb-t#mhg~+g zdyZ8;V5WW0Ct5W2B|NViT&CXw057sP7~1RPETl}l-J$SP-0ZvST9rWVBsX-ohbx{ z%EjN$Q@f!VaknI&Cbq;YpZ!dbZ{k}6ZKPAM@$_tJCo;s@40g9FGs2NB6Tok)W%$trMc7^=$ubN7wSDy1tVOsPAU$=e31+{n5!xsa9Q2E^1U?D;4*#EoD3I+!#fIxy`Hs7 zNb$r9C)Yl*Z8_$God0$nZkM`{yjt(o)wL4)z~DOB`XX#9sM#~yp8-u-}GF#|zRiEU8zc=HhJZh;LkWn|vZ}q~9;ez2b zSncgtJ-)mwZG7-C>xOfTJwcHK3zwF1vpHU!ma`)eU|Jq}AllCQ7Cdg<|Nx=ZvsD3VkA1p$%kke7$MQ8YtX zxSKvQaIG`@^3^sEzCUJS_>&)KQ~38=mqGJWb|=Ic>g6Y4sf6#_uBxnOlSFhOB0sZg zirzEDBB$9=NXm;cQo0;5i87(+;k_&PXc(mT*8eVI^WAkqSGaf`F=eg_(-9&s&Z-6z zPaVvqK*wtDw^_x{(h`CJtZ<)}vg0qIyp93YvxQ@u2w@rDPuX}|wYH1fl%obxl&MIK zTE@Q5ygPheB{(!%D{+=$8D~1k=%T`)R4n~o;91iVx!tc{2A9MjP((5jY!Uv;zX|0r zKlAjjJ4C8m;W-T-b>A7d)agHNyaj$CTg8vD~{`iEcqznVhNq$q+yj)()e$d=! zH6ZNU3UtyLM!kj}w_TDa)&i6dpa%3k2=w8!kdizGp;S!yh8}}8m@_wlcV_=ewSYju@Bs;Ja}tnB$7Y&W8%>QQTNOSB+zzG zC^BGaZ6p25YwJ*a#tSFP=G8s3&f1;XNNT+Y{FJP&XHC2-n>5R99^&e@4(=DH@0yRp zCL1mX%+G$LQZ;l_K$8Mumpe~(2QPQ5(5(&~k9W+8odTBgPwpp{n#}jt$@xJ&9YSop zC?*8vSr5+At1LI50aLM>9or_F`BW#1gpCdkwj|z0#?uHeLLQ z+|JdGj0f_Q^aI?|Z_l2C|L5*H8aOCgyGy*%vqvDH{Ftxx=@lN4-;(1u19OVKPo`n= z^y9M*QI!yS!!=b2ylCkseLujx|DdRp#eW&v#%jMcblDP$&K5G)FzB@%wMbKB~?GHEX$ zg&k(^e>z%SeK{~^zFc@85Z9}ieSF6|?tZAq)ONS+P4g5-mbXSBR_`a7@ru!58yZmK zB3nm#z3M4sm(`(8-vlah!f;lLy1fNKnP{DdqXJZjyXywa_7OmsgI5CIq09n_)sink ztIz)}4GFx*?4@#FN0!#tXjAR&AM1`;`(@^}Jo+Pt8O()5b|2oaaymSLatEV;n?7e| zEN6&k@9sn&&Y43s-9IOm-p!-is*)K`E>9-UHOL3v1mX|cv`*drIXmFPaG$eZ6<`P= z;cSSw1&RikkcVM)H+;OFqZ!^`GZJqr5?6kj7w%}JU1YWnMJ=fGnu49ObT3Hie+vkJ z+Gn_BDi*qd7px&Bo$^|EFhu>R>c5#w6X+YsdtbwG($%3uz zOWIOz@ZURK`8@?nBwoPQX6a1|y^PU84r~9N00SZzq`nn{0)i3;nt<;cMM?vmTi}JU z{do@QU)fdk640$T-_H#`XmdNQyxd&=pxx>gZ$CMmKRC{?Qgi}yk)I&V&_ho5Yz6;&T+69%_PpD1S$LUy4P?r9~-(U=Wus{5VyAjvmXX zBP>k;e(d-E%bMcYuqqOvnF-OhtI*Qr5v7feo8Y!y`KyEm6knF5mp%%sEuO{Q5qevX zfrU}rh9pZ-y&Nxl>hgmXuit72WntT=91rh0UqNhDJDkxw%z(+-Uvo3A_Pn&IXp*NW zJR$c*9m0ycxw4$!J#Yh{74QOd!TQV9CzT~WMbd~ZBHc^*6ZN*DhcM-a>2as}eCCf% zR^8S;o(TK=0dp-rPbQkrzno6iiJqZ?e?@$2^84{5WUQbjy~&`L=fu#30G4A#sYBfn zRrJB1413;+lCSru?-K2xgHH}Kbk*;RbOAjrV>S^z*uun>VK(wq;3TO1fUm3p17A+51(1pEK z$y1kuFKQd$S1;Cy79cQ^Ui)t*#Pt$9Nd*pRJDQ9 zO$>yDtVfJ5+~T-L-bXV+|IIV|-&aBW+fjd~3TMthR5_q)TJGgv1_2a&l{V|s<}}`BZEcHlAxWO$_;vOiAHZ@m#!2zR0w3BwB@dpNzYZR$2iuC)fLSl*Bs!X2X< z&qf2#uz}hJ*Eoax*r+jJ=9RCb>q1fx~_;eRo#``ZXtZOQkJmFKsJ4fcfdZH48 z)#tS8ByoyJH$0}KyD_N!RKQ;ugur~FySn;INf^NBNqOZ`>pgVwl-<&^PR*KUJs1l@|Bmv`)hiF!mb4hRb5U5 zH=dvXzG}(1@3>wUY3XbrnHOFkpZrzw`J;soatt8PC;!Sv{aX>i|8@5jQj=$O3R5r! zcy4wcf!+O;C&!`|oB*ItvW*n#-`GkZzu~vfc=f>1o;b10HkWe_ffyP>?sB@?$MK)G zN9T9eM6}d1*^PX56f40c-nTN1OeF+5;q-l4_YQcVb`T~7j8xm3gVeA~fu*xewE!zX zI}uiMW3XrSYSQV6D%-_^x7}JNlaD>R-+ru4^`rzO7*cub!IA!q>@7BfJI`}OoPqLs z16awWVaimlK`;G%$w%1&HfmnG_@rDY%FIRf2cl;nbR-G|^e=A|M@=w54jTV!25EI0 znC(iD?=)ENCI%m@&$XdB2N$uU;4a(uAV0%LHMAg9Gv*UbQohr6c3+$RrhYVvN;a*2 z3)3&a`O09+qNO)7DhWFFNkBErGshtR;`sYauAQJ z-bLwhE;g_^S6zu=F2X7hkGEr9padxZz2 z4P|Z%Lz_ltwH%wHNnS-81roh&^^yAER2eR#cA!>yQ;fKhDa_D(zT9$^9X6Ysc;~DK zYX3?q0NvRq3m?gnV>%zJtzGmsf@Jm+z zV~sPCXAGCeo37HoB*=)^+n1Uq>_ae7cehGFV6lSMc%) zkm1JoK5=ONcVkAh!gB{!#=!pkvUd*cLipNfzG2ZN?iB@Mz2^#XRu)ocZxzT-(W%0~ zZL6s=(WAoovKRaKAo9lBy?TN+-=kQ(e#8DyzZw{l#V(2$nt~-FQeoY|%)Dq}b`{SV-l^lTmSF$~^b9xU-Vn?e{xS6snu%+Ywd{jYAAY&e!Nc>#(f;_SVD zB6>B_1#X91gJcqov4D_V1^&O$Dh)QQaj|#y5+Us9{qff+*pWEvZv+cvf#-G(8)5n0 zxYCuR$J;XyY-%SL&`agA_P-39bbk7qnWwHf>NVO zc(@gtMzQ^L+4c?8Jql1((q3azqJc5>nUD%$oQ6BAv)dwE%3suYOJrJun){O(HMP4} zE#Q#RC$MnW%%4QHOrz`JZXUsvI3-afVq4ai+)pd4dtSnBmV3qP16XctH8pja+*NT1 zJAv3lT?n6VUgqM{s8tDRZm@YhGu=jjRPUfWRC%VW3Pe zR{CW5($@3#vXmQSJnhzKECBWo`n19~j~vES|hDOHV%EYhjk6i(2f|>11ZSbgvVbKSQX` zH~37{^DGtKI-BvZYR#HFJd!0+r_n?!KHoX~=gJ4H8!4lE3pgW8-w3pijTd`1(IkJ8 zi00Djy157pnX&2C!s&rJZ>MkMU{C!==v+pBJr^&MTa)0oE#&i(c-^1n_lsV%CDe>h`jsdMLWe8DtneGZXo<$_0uTDm@6Ji5FD6GVA?*7K#ssdov^03lG=I3 zulTYu8#j(Z#x`@t5#-A6BumT5zKx0gy6axJXjWO%lKu8YzenKb-kkyp2fvCkfWQ^$=Y4!mci_l1%7)j>&an9+Nc>D{V0HtJue2MTv-^g|47Sv^)bS*6i zkd*+F2;jEPRxXv4t~%7LXEZCEtYq3ewGw&PME7bYt}*#~3UA3_Un|RdF3J#_FcIcA zb!$qAMdUbgm7XAS$@bu0Jm<}$^PO->@H@c6`K? zy@^jE{81!{4co3dz71v7KW!~FT~FRjQmEvW9fqr5n)3dkQa{fFU&m3L)+ zKg4_E-Hb3yAtvHjrX!N=ki**XVggEgQw&rr92^-+OTvSjM4j};(uiPXAW-|~(2kKM z`FHhcM}Wigk4YoM4Gr3|4Lt0(7fVZgvLXi{eMcowwp7WVZ==ngucXs<5)QhgFO3SX zdHw{!;+!hh#nnD9u75mxFXWmfIT&aKn@+YhA1FmUR z3Sap!bgR=nf-tGp)w+$F#GlvG=&Y2lc|gs0B?bxrEBG&2QAR%rbzSO8U7WQ+gFgk? z$N|altt05x_qoT>k+Au%bf1r{79e|DkKnNK+V-lVP=2hqaCiOfEv2aq`6Dm8G61xy zEGosb2|$DN3Ya-|QMxmqfH-nJhUKcz`~5nd$8tU*GX|m49-H#`?YLI1w)X`cp|eZ5 zngj@(lzf|ueZANBo_RiE<(C4!byk?kH#HFp<;JPuyGkHrOmibP(mBR#oK*o=YDfyu zNvm~Yv>ruCbS|XUc?#kHQ78ZyW&h~nUyrQ@1n=JHy?_BoZLFa{X94hUyoT9Bzpn>2 zu&W`~He@FF_at166W4c-%_f_1Ev4N+vkdU-UwAiZ$l}4~g1+Z&MmfBcWaVy#LBHva z*LTyt^}_ddTJVNp_Thv2V~fLoT`-o*4!I48ZoR)c^o5t-->i7T+_E0>A$nK(_va6H zcWrmRck&OrH{re~J%?=%gucfV53_>Tf&dKD=hO0*V@18cPX^o@XrG`=va-9ZO}6(v z1$shGS2W-gD|Z>b7i(?Tr-BdBf;Zz?5BG=gBcPE3F8FzU1wM`?aHsxo(p#+Wdq~)J zo~Ex~BEel8_0PkRS~PIC`EoQpEa+Eu=C|^s4YwX8#B%*sZ=>3LTo??NeMqZq3gG=! zkLoteiE7luSou7lZ3H?-)FC0KFZ6UKmr>~&Y{ms&8}W#Sf9Tlo?qyxhOOQyf50?+{NzRq4hkH)>rMuvVYe8RFvVO}=c-uMJ z%3b83zP|VAVRNQx@83@tugf*)=;i3MghD-dEs)RrG@p334bBZAaK?T!bjoHtV@@Ae ziPB0LccmrtfQIF*id(`5pSQN_4b`RWSi3Je#Yb#&NSYCZ#G6K%zI&s+JG<|5&zS|M zc(|$_^#NZp`&Z4G?+Cu6ZZG&CZx7!W_uV3VxUu)%JF)lLBPkwi zyW-XSOBfxj{Xr8U-$r+8>4xbirl^KFWQ3F6De4W#aWM?U5n0J;Vv65V?@iln$78Ehw9nb0;Pn-=z}?ZL@2S1d32z%bU*7jJ z+UMH7MXF(mGpjXG^|50I;3Qox#87wW@U;ljsKjZul$|*)vFyB8YTUP$`+aUxdU@~Z zEd~xtYbu9n>hVQ)yWVh3XbNqPB0wV?a)1Mm%Y*dEqG0g6d`fKxCp-#DuM7vFJTy>5s# z^i~T*9F$06Zy@`J8G)xv!qtjdcGZFuF;^5~bVLLaV3<%iL zY5Mm6?(`ry0U>4($nSWJAL98NSo==Cd0kCOi^Da4Ny2$=Osr6^|}6a z6SsgEI!Cpon{6MZ$W!TVjm3BTX`Z0P!=qNYFJ8jrUE2#SD#e+wV-_&mxA@YHys@c0 zZqhtP`o;mV?SZr15ZmCH)1HQbH_YRJ5K8uEdiepBM144AHddl*jK3bh8jrUT2$ zY$#2WL95#76Ear(*+K6x8ov^;MQin6p z^NUzkJdV<(Q)88;hLi-CP({O<)9N!!P29IPVF(YRN*r^cX!Mn<{cDTqj|cNAnB0dK zI$?TJxbzV%F6>7Jg}_;0PBx`+dl)?wvRh3}q`Cq3jLC3OaOMfSTK$&aViU5dayQJUZLA%W{-jBS-ReJPp&BE0Lj-HfLuAL~y zNcVIX4(^t*u5_yOeV!3ki(r#>VhR5Rn-aD z5$rZ6WyVrsS4??P?>|WtR=tLT!)Q|ck_r~2W;ruVH8<00;rc!WvL+?0oXtGr<#R zIEb*V;T>M;^7in#ZD;Gj(<&Rs2_fjN?f@_}j?M2zvhG$OV>4|Vn_^qmsN~D4EX(oU zZv3kiSMGiNO{NTvT3YI}*+cp2vP262+_S?(%q7ubkDBvFsm35ki^jzjw}eca=JA+F zf5bNZ?->$Q1O+t4f+%_{F+r+_zsNvu(v}!^pUx9y9=UC7KCI zVx*rc^;SfCk{Bp^V}(XAzAIa8N7G-2`KDU(gF2g}ei#9(A@D9K9e#;~_>IQ0npT}Z zn$ff%i20D0BWh&%5NazV$np!IWFS~lA7VYDBq=NK&0xle`Um?9^G;kUtv)q22`)dg zr92bonR%V!iliSwKO9*0XXYUnKYkWQS&7ydd7d-z?8EZ$rH4oAUL zL|8$k2C}Yi?Fp+&>d%F^aKFlAmTI{u>!-S=#SLp(JC}B9g%N~xVpz`GNYx34&n3x{ zDWZ`%y56ksx^+#@MWklf&LM;R_^aW2U|u7^QW)-j?Aj-iRdm-LRgzDW!pc?L*0yD; z8q(v!iuL&Zb7XTX2&^1?j`JdpYBRrUIP=V`!es$k6`1<~i6`1~_(8Tx{388%f`jo? zm@*=WXz}-NM_{>AE}=SyB_Q4oY@{gvA>;fO|Ndma2Y@m^out6T;;N@!0gzTxMM;k_}TTQ{w zGPU%HiefQ@(;i%J9lO$FWL<7L@`Ys*D$aP=&X_ToG2LJ_YHn+i0JT_BdJdECJtZl8)i!m533vI8 z-E~Ut6A+7qkVz!oNRo~K#TBc<>$epY!yW3WB8q2iW`c#XQhBjI$nr+H_BNaucwUtm zOivysTv)*$SFaW8`rIn5I5H$A3HfCw66Ma9UtJ6cG{4pe+J7b-^dIxh!Uq9BUiY0x zCuzgy7OJnsRkRqFGl%J2M+H;EM@Gg;_8iUmfuTV?-R+BZ+`hcB;Z&~cn@gJ~9Qc0* zo8IN=4EIYu#0QNoa53uy$y#R4zHi}m!|Ky0@sh-?t@v|LH#(y$*K0j@`Qfih6ri6BjZ)$nihw*d~BF)!2ghI z`!*4H=^#F6czDUF9+gpQ!juv%b#}li zCcu;XDZW4RX`0@jTf#~U5UPqsD_r-T$sq}3Tj z$=L)QiGiEaDHq&@BPV~(Ak{R(0*A_@Ig>cKucXecI#zWvsi{=^$MOf}YbA|gX!j(% zHJYYU4k7##GX3;ubqHo@WTbkd3$6?!y%jwS?7Kc5@}~*N5VJwHy(4?nP&!0BH+i5x7~h7pH|cWD0IJlZ>QWvbN`|s8bbjhlOw> zOUU;b@fOFW*G38zOJL%YuqqhO$Yg4AESO5&D=!&o7xL|B*Vz8D49Mt-TZWf;z;yV0-Cnxdhelo-dHG*5RuX}|}Nlq+_3K1+Gl-apRSPeZ*gKKf; zam~?&Tb#{dwj8_W<|duxyiPCosvtXMo}TMbtD)U-U5b(T674*dd7-^p3diQ;X=2&*Sjwt1jf$#L&6v>{N4L$V)1@ z;8?tp27Cb*v%@vgs8i#hw6s^ns2&t-7mKd0g4OGj-dxgtoUQx#48< z<%(YK26=wXskE8p&oC#lZGufbPZsX9-*9Ab$ej$0jupZWlWnWJj!VW#M=?p;M-OU7 zgN5MxVmJ)z>9tC0XXbA~s}ehIOHsmV=qh-`@UWhDsHy^a*BBfkNci&&wb6Um}StHs9&+3RM4rjFc zS1HutTAU3QDRA4J%i@OPt2>|E+@CL0(F_u?`9mmDZHdfru<+N-S(Liz(Z**RGyd`u z0WZ5uB1nM^dh(mrK&-P|UzEqs66ZsNPkXd=q&r!_@BAyh-{G_oIa<A9+(7_Zn4YteOL)UR<^Tu56ENGfgHd$!H2T}Dw`0$xMi zFj4~ZyioR?sP-Lu z4n4RwmaC3ZlZ>47kqbfX=uLK){hfcnJ6qKWDc1>1itEuvvUY?6?s0+T!ab=r3s7r{^Yj8q!9eOE+ArUE- zPk&2YZ&+MVaeL>&(VR4?0O=;d-f}r#8C%>~kh`PRaNLBJ%x-vRT=EBT6mAf^tlnMy75({d{V-XWAiIgsG|oPHlkDI4<^N$#h_IO=;3FQrvKavZXx)s;}f^+{IPg zfk}4s+Uf%o+in8?HpY|u4*R5(8b#4*4v|GBuIps@@C@rqiNj11GD`dbOwM)RV})0IhGxnVQ14b_`1Vss)#$h1b$Zh1;p zgJ2baz5|RsZceUtN7+;uX<|gf@N|c_`b&<_L4HY-Qz4-&%6PuMj8NOKyfu9x^yiX| zi412UQR%bV?;kHroE6@P+ZO9B&*%%oHs8Et7j9w~ELnx%^bO z6Yo{xK^#s9@5QEYtoni{JQR1GIy7b`gNF*{Gh!}`t2aQ`61A#_#sp=s{bt|M=pUWJ zo*7fpZj$A#Jw`bZi@^Qx-4lQi(9fy&D(_dEvcb9lUpOi=9S!+bo zTF^d#*wK94whx?m*x@Q8s#S6(Osc)IbQcT*sDGTT?sL9Q9&VScxgYeD{7mZ#t>Pr9jBX81w*P+cFqw4w}Yv+m)+>YXpw^`m_9oq2uq zpHNla{|r_APd5&|e}Ci}Q=xMSA^S3FH*5vZUVJItf~~W(kgvhqHCTd~*JU8;Yc2_FHx$+0sM`}^d{0DaAcrJreKb_bR=@$m~C0>y%G6*3iV?A4x)Em8M zPGN7T3z=0I+4rZCq$4i=w3KBNA8$q=+%_{|Gyk#Wxi)Thp7$~R&WRPa+GujP$D1gQ z+pJdZa(s+?Yw3wJrW+&ZBWteDDLpZ1p|C*6=tph6Kf zR;9Z&j>n?!U8J^*;Z54qV<(o4A2$fu55$lEKG$PqTYIifzv-^t-MW*@vFS44qt+XI zE~2|^L`+v#9KyfH{dj}A9x$Lu8UwB$O>I~d{I{tGw`rXY^_-x{Ctr$-qGpdpO)Z%PH5pbfj*KKyEk6f$ za(nHlajiL8U_ct#?7ehuh+-%pX2j8yUL!?OW5(1t#7oJ~a0n*PGVICa*`kleqD zBE{}4UZttQ*tyKF&$QShGd!PNWgWl6#rEst1e2uIY3WA?zedJsqjNQ14qMLl(wsW& zdD~QcK^^YnFxA|cn0YW2N0Xzhc$u++=W6-eMUVYiB(pjBVGBkGv}073cB{mJF=Gx13_uW5Omc!Omx>WW}Aa zW0!gQ`vqVp=II{2=BGO;e7jFoN_(G=DZW&*!y%=cw5y8|BSQIIsYRhb0yQnXROL*Z z0gKAhF2l#TP36K)T6c3jZJNFJonwgQ{3g`0RJF`y@3alD$Y<|&YCMcOlPQsCGt$KO;>WS@R$YrzSVDeV zi7(I6_Y1Cc9zT$RDB3(jUu5U15f>?A6^uXh$6p`?>t<1{>ir%Plr#TWH>_tvP!HyU zy!z`qs5RGNkEGP&{mk!dqi1em_(tGbnhd}57q=SH{ z^xk_Xv;YADM37#km(Ub2w9pA1zTheMe&f9Nj+?Cx*N2QM`_K&^+v#RSot29QPDm3vwBBu z%bhn?;`U~xe|+zm;b*!l{S$P?5kO6aZS5@aVuT}MPAIFF1HB*i4sfsX{ml9ZcaXuC zlT>>(g*3G~jU)J0)OX4XZ9|+FAU3tWeLL8msm<2i*myJv<_1+1XR9E$L~Ld*@j=TX z4uXt!ImMx=-gNOY0`A8a?y|9^;B12FI)>KCSG?dEm= z`STmtY*M77MO9tEc)^IvQR7`}bH7>NM0)z6gx*PW#6i2(bo?)`j4_eZ(r5m9Bg9TS z;y0Hv4QJ0q^425HRwYOZXQog0jgqFpKvC0^|io$vZ5boJaTbionYBxc|vc}fE!RF?^w|>V41uTEg8Vh4qkblMu0p^$_+075WdI}cI0Vj|$Q>SUf*b^gJ=~2(x zuD4FDu-|qa=XEA&qf~Gd<)er`w7>k4X`unV z(q${QmudW{($&6Z+(G>@HjV)mrborDU)Y2xjQefJkJZw|$;vbt_&~8l=B^YyUdiS3zbCFJF`&QF#r0dA5;LSPr6%>Hoy85}IKGWv7&S zmwl^1LY$k*F8|8+EFH}0Q`~>;;%h1*(=8`d5cIL6<&kw=?l8Yx$&8^@57YocgG(Zd#U35Ss!?r1gH^yvCyyqE>k!zFtxpDB zgD)LsA77nwGE|XwQojjVdR0X~t)FmdKsH<|j$kOTa!tt@N30)0tt7}fo;1b9;)NIR zWEPp3$ndtUHGsQxVSa(y5>v0|xj-F#fP;5)TXfI^`T?2ft>xzpe*Cck*NE3iEir=+ zW-_xZaUvT{V-nwu=CR>xn^g zF1M?wi9@&MG0a}@!cg~H_TE-C{Qk(dE81(1@GVfzxlgjbzlT!P9%V-biiW!h>VCgI z1NS)O?769Rhi#fRvlqxG1V}yQ+%3yI+U9sB0Sq;P=3VMjmPm84SNJ&fq|~QWXfzeS zP9tbkw%sVqn)53&vG(bHvqHVh!0_$wohFpY-6`pis!dRIDW5Hc6XHy3TeUK)F^OOX zG;&O)5Q5}iUXXseJbHSr@49jj$p5|s<6U!KjuqN6I?q<#CFhK;HUyEQQH9T|>T3X9 zGu)d{^+S#CoDr>wOOB?aZt6z+Z7&@tH!RpT&Kq)kNBcH3#uU0vRJ2HHfAN<)3XrQc zU%wM{_o*N{VsgP>BABbz1(oJs0l^0z4CSA16PUxTib5WV$jc zcr^YAkyzV{izit6p*02*$ z)Q0nP5G-hd40NZmKoCPh9v>3 z;Mqe7wdZ)coy*COH8vf|Hf#&dB$D1E_4toBNq1`7wd)bi)NChQZ*c02=F)!VmqO}5 zFjWz=qOSYPRhyT5b*BNRaHF?;61SfUiH*+i|Ibn1Z&YyyeX4pA*SUq7xu9nQlQ<4r zB{U&v2H#kVA$@pl;odl$?2SCmHYn8CHyUl!rPoFE(eJba?42nPnhwt>d>Grbx4-S; zm4=OBR3Xu*__dOM-P?|INGGjmFMK(?nYkd>UZZ=;QK`|s>_Ry?F{@1d#f@h<;zPH6 zr?BzY4*Z(Y@m8L%oqUZthodaQ?nxMJGAwzQ!}uX*hB>}0jJ?C71#V=Sf8qia{5o&Hi4;T_ZEe%7m&OT16_dF%-);Jwqv#Jd`Pu7iGQS$E6u>zQu63FXjtQz&u0={c@TpTrluS)+`07i#6bC`qAVqDJj* z6>mmdIhWMQFVeB(SsgZ^c>uF+M_KKSD*ZxBC4#nSE#jPmnvG%dR3+xvDs_m-!B`^r zCfRhW=-c;mls44*vx=b*qcN1?Zb5)7>&+LpLU}G=M8DrHP5-N+1CzkcSO{{QzS3bW z2mz-Uq4uruzL{=Sgg8k}OOTgznECE4WGk@iRm%&z;RWM@rYbmo2$PFez{ToJDsLY$rLQLw53G7TU81 zYXTh~le;>eY8^Z;h0i%`aQ-q(=T6FzSO50%i4o2OxD=c8^V?TYW$Y1EtYY;0OEdp- zXxha`C!1-+556f?P5RrF`NoN;wWZ1+owwc5WG+o9{4?d5f7C_tsCOrmHY+VI*L)uJ zyisa+NUI4Z`qs?jdaEK!%JgK#-C_~144d#mpEa35zc*Q_M&DBrrlCzp!6%mf_g_a? z9|enOSG2b~%O4(R*HC+#W^gd6On&};l)WO?eO1!XI|Z&51kJt`iEoX6 zr!9Ws#x=e|@FvBQmw)aNQUzbL{EU?jAYh})8ICS?{u0L+MjF4N}ITxjax`y>F@#MoT=ik zHXzS*b)S1QPSTGp78E;4c&!nZ2b^`o*IxIV-5fQ^m4a#d{_tfw%62F(1;|yVgolaDGqXTNMQtyPD#eE|OmmD*bg(0e#@O_|(#w);Y27 zNDVGlhNeVtne};rRTgV;99!H`>bf~f zwepf$07-*NV-HIOrB=@AUI)GIc+ElwMRdBSjYMTp;O1n9-=E*^mw;rW@};VN7Vd# zM?cKTRo;&!klLVjR}X7Qme^IO0mZ}ZCxaezD1D)vV2z?%NGtO=XtLZ(=0^f&yH8yRz;96j2j50E_r)h zCxf$kg%dVs%I0$nbG}Mhu_HquT?17Qx`X_d5>)LAYUqx{Tfu#(E`q`gaMQ$qx zFerQuC$~1LJ==Aycn&+URg7-F>g@I(Sf6j2+m7h=FFb2%uo&XETb2Gs6!V=kL;3yAqoGYEiaR9xv}I%IVfuzC22s{ZO25 zFseU~a9GzdV<&t}c}+9x^2rj%iRbL2|)xX91U zWNcE=k9P}_5w=Bh_x1O}K;U_?Hei7meOUP`9UPGXR?8zfH65wIhxBH`%008fjQ}oF zeRk#%clon%$+qF9=8Uz*Cxo<+xdg+Hu0&a>J&eN2+`1AE!jlmpTWlPRUhfkk(_|Ul z{RKyObe5*e%O_VNtq2V^Na<}24c(pQi)qr=CxHEaYBiTnZ74aH4%ade&P4mL`NTVQ z>n=o9-9MUhizudU8#}*I8zp9)-Dcu}%FVZ$>4!TpGOzrc9bsQnfQ{7D4glUJ$fa>l zm(Zbo2lK1<8@y~WBFG6U2cx(MF(Q!DEjdkT*lKnHLZY>p&@X zeQy%v2}|=$4&o-ao@@HbhEEc;*bvpw^eUJElX@7#@qM!_Y!=33fgI(IL_t)6yicb- z4EL5^t-aweNm@n!)YjN$L4p$ePDMHD^ondn*Rut)RzULzaAYw3VpL>(?*rwK44lOQW`t2cq>UBt1v3_3+W9D?Ns+h6frG682YxgTI)N~ zGXK+0bT06Z`d;O~vYJj$up2YHHJ$GqON;*2C{E@7x7lZOYsJR~fEaArf`^r$;RSJD2f%CkC!VZ2WO~|rB4LGgt`hC3t6_Q_S zGy`RN4MFpf3_OnBJ8Ce@Ic`3sQ~2`BHRGsX=5lP4nrja&JsbY4)Opr}N}inCZYz>V z9QBUsQh3ivqz;{O6g`|iui%(Mmj@XG4a(>2u=*M^;Py!Eo80Vkxm}}AcOdDGtLB=0 zTf4R#HEFhI|N7z6l>gYG%k>EJzXIsZ>>B4)96KmK6V`nNLoE3A`>grh zHCS3cpXzCztm7(?C}^URypBea;}{_fhYVd!sj0jAnq(8kNr38Z!v{_!_f!ue7{zqYh+UA6A*crG1L2_ZISwTPVjM z?FVR<>M=5J+uOAo+g59CdCW+uZ?>e5nru~)`KqGPPWiGyv4~$Pp?U2{Y z%|wj_CliU8&eDhENp}%>z}A7E)KB%eG(+b8z+};+n&D@1&_ooXV~9USFggu$^m>$+ zC-&Y(|F##4mOtCoREhZGorS?}7O1Ob_ojeiO&xV#^?;P_$Kxa>Qp_pz086jl;kS6! zumI#KW;qI~Vb;}5GusN+s$tQQkgGKBdG(o!1Z2T)Rl`W0#hkh~>1miTRN;advY?!F zrGE{m6@6S8kJxkPqhIkUyW|}^Y&T9NNB5%a{0gramc0BhQd1_HbA+;|rcBy8Z(Qx% z7ahh>w0x}&{$GkYVIwXG(F04udQ0YlG1v1@=hk#??Fz*;SKUdmHRV=WgA13N>I5fs zMJ_1J9fX`2?sq}2D_DEzxt(t-uqY~^x$P>BHZ{7rcJNo1?>hOhK2435o~6fy zY&xKYKwTd>04{|Kpih3OVc_Tac|a(J30gl4X64bEp4J`j1SG9MgoHsXRBU^xGu7XR zVw_$~b@l&!L!HfuT%E*@5aHY0!Aix40c z-fb4cjAa_8$O(|6=!oWf?kNG4||{_uzN6st#WbKq0aaHXC&%I7O=a=h=`Ok*B!ij zna~^gZjt=YrYsr}k*H(Rx+8vmv@j(523jjtVQHec()fOSFmkx0H~JG$?^tYYfdhFl zL26a4+aq8)l*dAQthxcU_~UBx1+K5hH%rx`qhk6xY)%es!y?Ja8n$z8l#_W1Ccj)~ zB1IPrHr~M&4I{Yqym4-OawfxCg1djFh&yB6as&nAF6rRL90#XWc`@p7y+7n3k)V{- z;=hxbsD->NQ+_>8mayvrI-Z;I^fB zg!OgC8g?^G(kAvs&(>NKk;rwa{k6NU-D0YQtgi>aFC@Z zl;Vzt34D!eY4zIU0>dcwpIaPK@PVYy!QO2R=wkF-o4UWj(oXB#Bds~l`on%J_vTuD zwLYUs25!xQH-RtmIXvVJl`v-%3KhKGjawO!nBR1>9fwSs^Zl|zxZz9K5)Q)-4Q>S8%{{HZ*F-tBBjgF&uVwS1> z5=cQ1x7qJoQraSl5faW?6DOX&dTFT`%!XGh2CbBvP@cV4Bqb^KcqE+7n?FJ=(Nbxw zZm;~fzqS=m-jZQLb}d0DrrrSmQ)31sO`pkYe8sgE(GWEkdAFvmh1{+S8jbL}hP-ud z7W|PINqXy51jg6fmQ2MsA;ZR(C4X9f6Go`3WFr$P(E{AA@`p3EE!S=Btt1<--xEo| zz&V__MKoC}%u{~|^rE&9n=7YYgRTjN)Hc{+7oN>Or4066i3Kbse!3pz7N#>xf~6O; z)bv@h%G!nG`T@gQfHMPHG8JHZgf-aY%aL8bYOHxIjl9Nad=Vz1z}Cb|8!H{LFEk%q zjd1^3Uy(c)!`sIp;IP5II;Z?7p8xPx_hkXK4A z>F~GiMJDBR9AkKqxc>2f|2N0wcRKGsv_brXtN$|!CTn=rn?x`~fZ2=~JOA?UQKjgh zV_yat-R>s{I43HH9g<$sGx(zqfDhq&@Wfw_BeTvNY0yXh9%mQldy;DYWy^|P1KctF z!#%JUm~oucHC_mqemapCI^W<|l!46cwGnH7~IE`!{Kps57@8LaP_x896j#*|qmujo}{H}YpbekWO zT`dDkwa#y(L&*+s5gFVdVzyi2$iOq`M+thdrC+8A$vl%~?^H?;@4cU9A!}@gU|Cb( z0XU1L?!|K{@m(^@9p(UlI=dRZN0wrVyr@sUxwOcQ*CdtSw7SAN>J4UW9+7EcMqgT5 zf)S;~ebb*luwai~p0I{w@9gTWj54qZI!F zVGez*671D|y6NcfQ$YIo>#55SyiKLUWaq~8MShe7T0@#FgnZk>8&mFtXrS$tIrNBB zmLom+i(d8-D%Gtal5!_A7CORxg zu4|xH5+k3H8flF^WzE}XxFX-KcUj?)9|MIrzy97@ zaw7Of_j#MYpF*V~e{CHai+PFI!14tjIuyB;Mi*k`yv}+hm~NJHyC^}|&Wh2H$F{`Y zL}BQKxx0%=2pzw2yRxZ|0;C>QqHcNzs{j~GM=JK04}w-n zrrr@AXrU?sTux>|de?ox#J;ztMgF$F|E`Hu?BfD3jWYf zJ+56hI+9;r;FxI$7TG>6yYtCGz4gmd-#orSgYQkLjo_QYgnwJ%Z+;$eReDr}`=!ZV zF@6`BTjaIcSgR{#WtsrUp|Txq^^FUm9Ls79&3jboG{23WPZBP2!y9TLC;gS$sEPg_ z?cPgbfbyE*7)Gg|Gjf+Xy`SYJy;*W!F-vWTmlnD#T`UDmDs@-Me81v}><^g&oJa@x zCH=_9^2Mn7n^5Pg2P=PG{5%!06lFYnnC#8&2++9uzeP($-QtA(3sjm~w||B#^o8;0l=ACE+i+v(4kw0lIr$aPLw@V*)aO(B6JKDy_0XxI za`}b5_!W18+h=Vk(ugtB3Hc%2go63U(ZhT&f%2$v&qRhq#cDQCOs#%7>ZPt`S#Lkl z`Dz9O(t#9!Io_T`_z&sPRt<~ElZmJIyJ{1@Q|jVq;fGv2jBIW_yu%FadBUT-90u+v|7VtVObJ0EupX2wN7_6THsu-r?a2%s6mx2Dq-3rjc}#uV zeN4|`&>V19b13ZAmph71x4z!}vlS6zO|ctqsI6}v>q}N7sPebB5cb;QfOiR+3PGe zQLjYJTq~7pmTcvhXk3+EE|GzE$7$fiUiaMNDj0r&g zM^R|yVn7++`9<`}en{6#S+tJIb)G}%lEsnp!p{?(96WpXpR(;ANT)KxC5hD2!A+MXU=T}?r^bs z!}{fHD?*xxqxVx^@I^$(;3Z7Vyw0gQX%#)e*OO#)C0|!AvH9$aG(ABiK73k=gp`_+ zNe*MUbWf((L%!QX&zr!*i#kJUi@i6 zwB4ESs?-yMMsK_EpD#xf>qyHT&%X(mF4QvYOWuR)*DU7Jq`hEwxFWUPvsNfps1~8~ z6!RjX^uF5Hvw3-#J&3}bd~GyA^M;=^wW62T%+<;x)o#>u8?Y{FRVtE>r}uGIZpWUu z@)@uwxxVj?PR(+*Qc8y@xDLvmx73#y+dQ`@-Iv@|c9qnnSAtd$l@Bf6QsIxyq1SZE zysIb$ECbtR=%kC6=#%DA*b*9tQH`n->g43pMix<3gF_=fWfJlMa09&G>GyT<7IkB~ zvg~zT>zpehB}NVtVR885<^UyYi1w{%Dg=D7qWcHbTrko~CYCx5{d}CSj7@Ut-pDaU zP2ZbX?54g#J2c=d<=`Eo>ubf%*(M>f%hF3uNq%3Py?80kPOF2Zr{lSPIQ1a2#2!xG zH~yZ*@(vR#d^Ix}bt>Bl7kf1pMTy}go+h0c2~U|ss>6<`^r_QpGVBXp*@3}E>%r^> z@-DG@q(OrnDl^#yP1kkKz)c-W2bIpOjt6PSSE@pg>}aZ;;8IdIjwZ-FwoYQx&#b=k zH_sfB(jKH4W)Y-FZ82u%2ki@LeA5G8MGJ)Ux?j60DU4lXSJTT+m#sQi^po*&-YK~z zGt61B1u)*K?^AA77&(1#_ZH=y&0*mpFV$uHrhD~}O@vGR*W_cJA`B^|!WP3{ozz%4 z(TGMFVgVBPJFk&=lbd`GI(t5x&$>Za5 z)-G|@iq<*y2pt;U*X_oz{}NiKJGupARVz4svuT`H`!+RQg9F@=Xk5Qh0LZjL87lkYE zcBS;9t0vBS^^?F+V}5bV+=5eeU*!TX_@}e+t)R)d(ETg1vIEpI4X!Q-037)0I6aT>`XOOaG}--nkasCSKx(z(9D%;*@z#w z@zqBD(ggbzAyCTWv4A5~Se(aX-v+mW78|$kvUDTv{g$^=Ugz}-cmLU5;cbIRpoNvC z>jbgHP1|WeT=t@Mjaw?OwURRaVR^T8zvqjiq7^5CL6?R)7vhvLu!ic-6cM4#8i8J+ zw0oO1SXcsyFCFao2<` Date: Fri, 1 Apr 2016 15:17:55 +0200 Subject: [PATCH 178/591] Fix screenshot Signed-off-by: Johannes Schindelin --- Debugging-Git.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Debugging-Git.md b/Debugging-Git.md index ce4c7ef63c5ea7..09ff36e7a71efc 100644 --- a/Debugging-Git.md +++ b/Debugging-Git.md @@ -64,4 +64,4 @@ Breakpoint 1, 0x00000000004018da in main (argc=1, argv=0x6e0498) at test-dump-in You can then debug like normal (for gdb), but with a split screen and the source in the other panel. there are some toolbar helpers and you can set breakpoints using the left gutter. Screenshot: -![GDB in Emacs (screenshot)](https:emacs-png.png) +![GDB in Emacs (screenshot)](https://raw.githubusercontent.com/wiki/git-for-windows/git/emacs-gdb.png) From aef2e98521576851e23a5638655bdd885eb3d7e2 Mon Sep 17 00:00:00 2001 From: jasonnian1978 Date: Wed, 6 Apr 2016 11:58:58 +0800 Subject: [PATCH 179/591] Destroyed How to participate (markdown) --- How-to-participate.md | 17 ----------------- 1 file changed, 17 deletions(-) delete mode 100644 How-to-participate.md diff --git a/How-to-participate.md b/How-to-participate.md deleted file mode 100644 index 6695206a54b373..00000000000000 --- a/How-to-participate.md +++ /dev/null @@ -1,17 +0,0 @@ -There are several ways to participate in the Git for Windows project. First off, have a look at the [governance model](http://git-for-windows.github.io/governance-model.html) of the project. - -# Help users - -On [the mailing list](http://groups.google.com/group/git-for-windows) or on [the issue tracker](https://github.com/git-for-windows/git/issues), help is always welcome. - -# Add documentation - -A lot of documentation wants to be written, still. A good place is [the Git for Windows wiki](https://github.com/git-for-windows/git/wiki). Tutorials, step by step instructions and general background information, etc. - -# Fix bugs or add features in the Git code itself - -Download [the SDK](http://git-for-windows.github.io/#download-sdk) and build Git. Also have a look at [this page](https://github.com/git-for-windows/git/wiki/Building-Git) for tips and tricks revolving around building and debugging Git. - -Please also sign off your work, as [asked by the Git project](https://github.com/git/git/blob/v2.3.5/Documentation/SubmittingPatches#L234-L286) - -After that, submit a Pull Request. \ No newline at end of file From 99c42c9740564fd1ea97fc6e838d5880dc7aa85a Mon Sep 17 00:00:00 2001 From: Shakil-Shahadat Date: Wed, 6 Apr 2016 14:09:08 +0600 Subject: [PATCH 180/591] Corrects NPP wiki link and page heading --- ...otepad--).md => Setting-your-Core.Editor-(-e.g.-Notepad-).md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) rename Setting-your-Core.Editor-(e.g.-Notepad--).md => Setting-your-Core.Editor-(-e.g.-Notepad-).md (95%) diff --git a/Setting-your-Core.Editor-(e.g.-Notepad--).md b/Setting-your-Core.Editor-(-e.g.-Notepad-).md similarity index 95% rename from Setting-your-Core.Editor-(e.g.-Notepad--).md rename to Setting-your-Core.Editor-(-e.g.-Notepad-).md index 0cf6da9bfadac3..f8f679aee856b7 100644 --- a/Setting-your-Core.Editor-(e.g.-Notepad--).md +++ b/Setting-your-Core.Editor-(-e.g.-Notepad-).md @@ -5,7 +5,7 @@ Many users prefer their local Windows graphic editor, such as Notepad++, this no # Setting Notepad++ as your Core.Editor -Notepad++ provides multiple useful options ([Npp](http://notepad-plus-plus.org) [wiki](http://docs/notepad-plus-lus.org/)). Install as required. +Notepad++ provides multiple useful options ([Npp](http://notepad-plus-plus.org) [wiki](http://docs.notepad-plus-plus.org/)). Install as required. The command From 4c2c56a33ba08bbe0a1cdce34da5c16cf5813710 Mon Sep 17 00:00:00 2001 From: Adric Norris Date: Fri, 8 Apr 2016 18:03:55 -0500 Subject: [PATCH 181/591] Add documentation on how to configure Git for Windows to use ssh-pageant instead of ssh-agent for SSH key-based authentication --- OpenSSH-Integration-with-Pageant.md | 58 +++++++++++++++++++++++++++++ 1 file changed, 58 insertions(+) create mode 100644 OpenSSH-Integration-with-Pageant.md diff --git a/OpenSSH-Integration-with-Pageant.md b/OpenSSH-Integration-with-Pageant.md new file mode 100644 index 00000000000000..225bf57d9ad30f --- /dev/null +++ b/OpenSSH-Integration-with-Pageant.md @@ -0,0 +1,58 @@ +# OpenSSH Integration with Pageant + +For some users, it may be desirable to tie OpenSSH in to the PuTTY authentication agent (Pageant). This allows you to leverage OpenSSH for remote repository access, which tends to be the most reliable choice within the specific context of Git for Windows (Git), while using a single keystore for your computer as a whole. + +While the capability is not currently integrated into Git, it's straightforward to accomplish using [ssh\-pageant](https://github.com/cuviper/ssh-pageant). This is a drop-in replacement for ssh-agent, which simply builds a connection between OpenSSH and Pageant for key-based authentication. + +## Limitations + +Since Git bundles OpenSSH internally, and needs a msys2\-specific build of ssh\-pageant, you probably need to use Git Bash (rather than Git CMD) in order to make use of this functionality. + +## Obtaining ssh\-pageant + +### End User (non\-SDK) Git Installation + +For a normal (non-SDK) installation of Git, the first step is to download the ssh-pageant package from either the [32\-bit](http://repo.msys2.org/msys/i686/) or [64\-bit](http://repo.msys2.org/msys/x86_64/) msys2 repository... be sure to match the bit-level of your Git software. The specific filename may vary, but should match the pattern of "ssh\-pageant\-git\-\*.pkg.tar.xz". + +Once the file has been successfully downloaded, the next step is to decompress it. This can be done using *7z* from within Git Bash. + + 7z e ssh-pageant-git-*.pkg.tar.xz + +This should result in a second file with the same name, minus the ".xz" extension. We can now extract *ssh\-pageant.exe* using *tar*. + + tar xf ssh-pageant-git-*.pkg.tar --strip=2 usr/bin/ssh-pageant.exe + +Finally, we need to copy the executable from the current directory to a location outside our Git installation, to ensure that it won't get clobbered during upgrades. Typically *$HOME/bin* is used for this purpose. + + mkdir $HOME/bin + mv ssh-pageant.exe $HOME/bin/ + +### Git SDK Installation + +Having the full SDK available simplifies the process, as you just need to run the following command to install the *ssh\-pageant* package. + + pacman -S ssh-pageant + +## Starting ssh\-pageant Automatically + +Now that the ssh\-pageant utility is present, it's a simple matter for Git Bash to start it automatically. Just create/edit your *$HOME/.bash_profile* (or *$HOME/.profile*, if you prefer), and add the following. + + # ssh-pageant allows use of the PuTTY authentication agent (Pageant) + SSH_PAGEANT="$(PATH=/usr/bin:$HOME/bin command -v ssh-pageant)" + if [ -z "$SSH_AUTH_SOCK" -a -x "$SSH_PAGEANT" ]; then + eval $("$SSH_PAGEANT" -qra "${TEMP:-/tmp}/.ssh-pageant-$USERNAME") + fi + unset SSH_PAGEANT + +The `-qra "${TEMP:-/tmp}/.ssh-pageant"` portion is equivalent to the `-q -r -a filename` options. In this context it means: + +* **\-a filename** \-\- Bind to a specific socket file (creating it if necessary) +* **\-r** \-\- Allow reuse of an existing socket file +* **\-q** \-\- Quiet mode + +By specifying the socket name along with the reuse option, we ensure that only a single running copy of ssh\-pageant is required. Otherwise a separate incarnation would be launched every time Git Bash gets invoked. + +Now start a new Git Bash session, or source the profile edited just above, and run the `ssh-add -l` command. If all is well, and Pageant is running (with keys loaded), you should see something similar to the following. + + $ ssh-add -l + 4096 SHA256:XjN/glikgdBoBclg4EaN8sJ/ibrxTq7zVydpkUwANzk Heinz Doofenshmirtz (RSA) From eb63450946d8cf4cd52dc28377d32a79a3b1858f Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Mon, 11 Apr 2016 12:18:21 +0200 Subject: [PATCH 182/591] Revert "Destroyed How to participate (markdown)" This reverts commit aef2e98521576851e23a5638655bdd885eb3d7e2. --- How-to-participate.md | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) create mode 100644 How-to-participate.md diff --git a/How-to-participate.md b/How-to-participate.md new file mode 100644 index 00000000000000..6695206a54b373 --- /dev/null +++ b/How-to-participate.md @@ -0,0 +1,17 @@ +There are several ways to participate in the Git for Windows project. First off, have a look at the [governance model](http://git-for-windows.github.io/governance-model.html) of the project. + +# Help users + +On [the mailing list](http://groups.google.com/group/git-for-windows) or on [the issue tracker](https://github.com/git-for-windows/git/issues), help is always welcome. + +# Add documentation + +A lot of documentation wants to be written, still. A good place is [the Git for Windows wiki](https://github.com/git-for-windows/git/wiki). Tutorials, step by step instructions and general background information, etc. + +# Fix bugs or add features in the Git code itself + +Download [the SDK](http://git-for-windows.github.io/#download-sdk) and build Git. Also have a look at [this page](https://github.com/git-for-windows/git/wiki/Building-Git) for tips and tricks revolving around building and debugging Git. + +Please also sign off your work, as [asked by the Git project](https://github.com/git/git/blob/v2.3.5/Documentation/SubmittingPatches#L234-L286) + +After that, submit a Pull Request. \ No newline at end of file From 2e67bd3924f04ba5681c47a162c5d74b75772d44 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Thu, 14 Apr 2016 13:09:54 +0200 Subject: [PATCH 183/591] Describe how to build a Pull Request's revision, or a different branch than Git for Windows' `master` branch. --- Building-Git.md | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/Building-Git.md b/Building-Git.md index 39a01d93aaa406..7b15b687fa04ad 100644 --- a/Building-Git.md +++ b/Building-Git.md @@ -16,6 +16,18 @@ We build Git for Windows using an [MSYS2](https://msys2.github.io/) based *Git f 5. Run the test suite: `make test`. If you are a fan of statistics, you can use the following `prove` invocation to run the testsuite. But first we have to change to the test directory with the command `cd t`. After that you can issue `/usr/bin/time prove -j 15 --state=failed,save ./t[0-9]*.sh`. If *15* threads are too many for your system, you can provide the number of threads via the `-j ` (j for jobs) parameter. +## Build Git from a Pull Request or another branch + +Once the SDK built Git, it is *very* easy to build another revision of Git, such as per a different branch or Pull Request. + +1. open the Git Bash of the SDK unless it is still open: execute the `git-bash.exe` binary in the top-level directory of the SDK, +2. switch the working directory: `cd /usr/src/git`, +3. fetch the Pull Request's revision or the branch: + 1. if you want to test a Pull Request, call `git fetch origin refs/pull//head`, where `` is the number of the Pull Request (e.g. if you want to test Pull Request #606, you would call `git fetch origin refs/pull/606/head`), + 2. if you want to test a custom branch, call `git fetch ` instead, where `` is the URL of the repository and `` is the name of the branch to test (e.g. if you wanted to test @dscho's `cool-new-feature` branch, you would call `git fetch https://github.com/dscho/git cool-new-feature`), +4. check out the revision that was just fetched: `git checkout FETCH_HEAD`, +5. continue as [above](https://github.com/git-for-windows/git/wiki/Building-Git#build-git) either by `make install` or `make test`. + # Updating to the newest Git for Windows version ```bash From 82b6e2b7a94de246846f586748e43ab92d1fb51f Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Thu, 14 Apr 2016 13:25:01 +0200 Subject: [PATCH 184/591] Use v2.8.1's description of the Developer's Certificate of Origin --- Good-commits.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Good-commits.md b/Good-commits.md index 8bb0b820b1266a..4c700476d5bae7 100644 --- a/Good-commits.md +++ b/Good-commits.md @@ -17,7 +17,7 @@ If you tried several strategies to solve your problem, you will want to describe Also important: - The commit message should always start with a single, short line summarizing the change. -- [Sign off](https://github.com/git/git/blob/v2.6.2/Documentation/SubmittingPatches#L234-L286) on your change (i.e. state that you release this patch as Open Source, if applicable with your employer's consent). +- [Sign off](https://github.com/git/git/blob/v2.8.1/Documentation/SubmittingPatches#L234-L286) on your change (i.e. state that you release this patch as Open Source, if applicable with your employer's consent). - Format the commit message to wrap at 76 columns per line. A good example for a commit message is [git-for-windows/build-extra@a64fe115](github.com/git-for-windows/build-extra/commit/a64fe115d901cab775c881bd1624218ac28de4d4): From d5f87ab1882439772f8fa218bdc48d690076a29d Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Sun, 17 Apr 2016 21:27:13 +0100 Subject: [PATCH 185/591] Created Release Hashes (markdown) --- Release-Hashes.md | 103 ++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 103 insertions(+) create mode 100644 Release-Hashes.md diff --git a/Release-Hashes.md b/Release-Hashes.md new file mode 100644 index 00000000000000..71623175a95067 --- /dev/null +++ b/Release-Hashes.md @@ -0,0 +1,103 @@ +This page catalogs the release hashes as detailed in the ANNOUNCE mail notifications on the list. + +Insert latest/new announcements just below here (i.e. most recent first). + + +Git for Windows 2.8.1 +===================== +Filename | SHA-256 +-------- | ------- +Git-2.8.1-64-bit.exe | 5e5283990cc91d1e9bd0858f8411e7d0afb70ce26e23680252fb4869288c7cfb +Git-2.8.1-32-bit.exe | 17418c2e507243b9c98db161e9e5e8041d958b93ce6078530569b8edaec6b8a4 +PortableGit-2.8.1-64-bit.7z.exe | dc9d971156cf3b6853bc0c1ad0ca76f1d2c24478cca80036919f12fe46acd64e +PortableGit-2.8.1-32-bit.7z.exe | 0b6efaaeb4b127edb3a534261b2c9175bd86ee8683dff6e12ccb194e6abb990e +Git-2.8.1-64-bit.tar.bz2 | 3ebc00b96607174fffb35cf6d96b3b3246aefa504a4bd30375182fea6ab64bde +Git-2.8.1-32-bit.tar.bz2 | 9e754d83190ba154f012d8eaa7433d29517f7c85fff229d4fb62e6418acf8d41 + + + +Git for Windows 2.8.0 +===================== +Filename | SHA-256 +-------- | ------- +Git-2.8.0-64-bit.exe | 7c431f31fdb9bb6a8575aec3099d6d4498145fe164f11cc9047c9ad4f885b1db +Git-2.8.0-32-bit.exe | dc27231c05523f76201a5f1c3f826a63872c4e09508b2fe1f84c8d675b986257 +PortableGit-2.8.0-64-bit.7z.exe | a4b199e9ec7b2660b5708a92959ff0eb748bf9bec29f3a05d0bd015f20c06da4 +PortableGit-2.8.0-32-bit.7z.exe | 6ab6e75281dc61a64ea82a79305073ccfe8ee0ba572a2f1ee69e31b2ce94b66c +Git-2.8.0-64-bit.tar.bz2 | b3014123ef9d269e2db811d2e5f116167e6e73fd0c02f64825ea37076d3a136f +Git-2.8.0-32-bit.tar.bz2 | 01b797cb633ad4882136587067f451a50b305ca903826f4394ad092a7f334f2c + + + +Git for Windows 2.7.4 +===================== +Filename | SHA-256 +-------- | ------- +Git-2.7.4-64-bit.exe | 1290afb22f2441ce85f8f6f1a94c06768ca470dc18113a83ef6a4cefc16c2381 +Git-2.7.4-32-bit.exe | 49601d5102df249d6f866ecfa1eea68eb5672acc1dbb7e4051099e792f6da5fc +PortableGit-2.7.4-64-bit.7z.exe | d32918f10812b4e60ecbf0524960cff00c8b20d1f0464dab1506d67dbaf8d6cf +PortableGit-2.7.4-32-bit.7z.exe | 4d5a2729b4443ab2d80b899ceebd19ae2cbd17a3b2121178def3590a7dc91987 +Git-2.7.4-64-bit.tar.bz2 | 0075cc2ce01729f99d86dfd1137494883b788991a5a9ee344330b1e377b980d1 +Git-2.7.4-32-bit.tar.bz2 | a4422213576eeac3124f97c5d5624635431ff104168fc1ead639c71831e97e27 + + +Git for Windows 2.7.3 +===================== +Filename | SHA-256 +-------- | ------- +Git-2.7.3-64-bit.exe |382d30d38b5c88690864bb46be0a9c5f53b7046e7a6485dbcede602c41cae9a2 +Git-2.7.3-32-bit.exe |e38ddcc2c17390ffec0ca4d5c4fb948b5b4874ea0c522d5180cf2ee7e63f76bd +PortableGit-2.7.3-64-bit.7z.exe |f5b39244869efcfac57c9a9f1d75119de0121bc8aa260d1824dfe5902f9a3f60 +PortableGit-2.7.3-32-bit.7z.exe |82df6b1e8ca8550d7267641e32c6b736f0687e35dc3b772b21914706f13cdea4 +Git-2.7.3-64-bit.tar.bz2 |dd81fe03c83e255382816a5db1427b284288fe21b4f89cbe3b1ff21af8d0ef1c +Git-2.7.3-32-bit.tar.bz2 |3b845331cf91e2a1677ba959d07491c6b04b8bdfc7900236a201d0f8c9863197 + + +Git for Windows 2.7.2 +===================== +Filename | SHA-256 +-------- | ------- +Git-2.7.2-64-bit.exe | ec4009b36ce855ab262f999030fff5471de73cf0071202138d395648756c7e8b +Git-2.7.2-32-bit.exe | 7b432c88fa7ced6a89670e9672279e875361651a0abcddbac6fea64a1a168022 +PortableGit-2.7.2-64-bit.7z.exe | 774e18aa40a35ce5f3c0002038937e341c625292c474641c8c936822ef77e949 +PortableGit-2.7.2-32-bit.7z.exe | 26d1e4a290a5741bccc944684a2ffc664676ccc9571e6077d1b8ab40a31fae18 +Git-2.7.2-64-bit.tar.bz2 | b292c68ede2b526db47692ec086b7eea61371bc9548c70e19f25f8625bd87242 +Git-2.7.2-32-bit.tar.bz2 | d9c2cbae64f3c581b497d2adddfa70502ae18436a222d4817c0597c889ee8d09 + + +Git for Windows 2.7.1(2) +======================== +Filename | SHA-256 +-------- | ------- +Git-2.7.1.2-64-bit.exe | 956417448441e267a0ca601f47a2cd346e2d09589673060ae25d66628b2abc82 +Git-2.7.1.2-32-bit.exe | be10e98b8c53f92648f8d1c85c7bad4c433aeedcb9d4719588b75030983cd76d +PortableGit-2.7.1.2-64-bit.7z.exe | 92310dec60b0210acbfb31a0165f2628757b8413efcbcea1cfc95b2984a974dd +PortableGit-2.7.1.2-32-bit.7z.exe | 7bf8da2b46f40c98d18a5f9c36e5b90df258936f43a0d230d0f29e0d729e3283 +Git-2.7.1.2-64-bit.tar.bz2 | b3170fc127889f8fa603bc8546c61528869a0a6d2c19bc03de9d96dca2443881 +Git-2.7.1.2-32-bit.tar.bz2 | 4c897917682685194ed9d71fdfafbed721488fe22ecd8f11bfefffe3fec9169a + + +Git for Windows 2.7.1 +===================== +Filename | SHA-256 +-------- | ------- +Git-2.7.1-64-bit.exe | ab3eee9558f5bedffbe5518edcd84dbade813a013470d7640285a9c9c263be5a +Git-2.7.1-32-bit.exe | 687e58df471bf88996a3ba619d25ccaaecd7243cbdb291f028abce68e8620569 +PortableGit-2.7.1-64-bit.7z.exe | 93b56b61973dce5b56127796b714cd29bd4777cce54e09e497dc1d0b2bb6057e +PortableGit-2.7.1-32-bit.7z.exe | f65ac7104a5b5c9d9bfa5b86df90acfe140ef5415ee8126daab050a157264cc7 +Git-2.7.1-64-bit.tar.bz2 | 2ab050864eaf60b158868a5a96ec5a2f2072a446a04dae9d290c4377871bb75f +Git-2.7.1-32-bit.tar.bz2 | a7b5d4d94b89e5eac5603c45ebbc28cb377f5835f6b3416f255972c77bd5226b + + + +Git for Windows 2.7.0(2) +======================== +Filename | SHA-256 +-------- | ------- +Git-2.7.0.2-64-bit.exe | c9f0ba628d79886427e05b6b2833f65630ccfc49ecceaab7cff0c6723d1d6e47 +Git-2.7.0.2-32-bit.exe | 8f14d50a1950264a7fd53128a81884f5757ca2b645e092ce81122993433657f8 +PortableGit-2.7.0.2-64-bit.7z.exe | aa29dcfffda49bde58c84d34cec8e38f4ea85d97c5bb789a56e00ab86a60de5e +PortableGit-2.7.0.2-32-bit.7z.exe | b5af00c5bcffd67c57beb9ce379a8080e44a2f9fe05650a8d7d460382832cbea +Git-2.7.0.2-64-bit.tar.bz2 | 9ed65a54b2586059a53ce64a57d2faa99386b282dd427a4a7e5474feb00d0851 +Git-2.7.0.2-32-bit.tar.bz2 | a9c2daf66ed9864146945e5e2e0970a13cd9140b0fb0327a668e2550a7cc24e8 + From 3c5a6a45c5006c06775043d279180ad0f38ff6ae Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Sun, 17 Apr 2016 23:54:38 +0100 Subject: [PATCH 186/591] added release hash link --- FAQ.md | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/FAQ.md b/FAQ.md index 2b8614d52e59cb..93ffcbdc006c5c 100644 --- a/FAQ.md +++ b/FAQ.md @@ -8,6 +8,10 @@ This depends on how you installed *Git for Windows*. The bundle installation req For advanced users working with the *Git for Windows* SDK `pacman` is available as a package manager. See [Package management](Package-management) +## How do I check the release hash + +See https://github.com/git-for-windows/git/wiki/Release-Hashes + ## Some native console programs don't work when run from Git Bash. How to fix it? From 1828b2d863232ab54c99c34a23c4498cb44f13af Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Mon, 18 Apr 2016 13:35:52 +0100 Subject: [PATCH 187/591] link to the 'release's page rather than a specially crafted wiki page --- FAQ.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/FAQ.md b/FAQ.md index 93ffcbdc006c5c..f0acbbccc11cad 100644 --- a/FAQ.md +++ b/FAQ.md @@ -10,7 +10,7 @@ For advanced users working with the *Git for Windows* SDK `pacman` is available ## How do I check the release hash -See https://github.com/git-for-windows/git/wiki/Release-Hashes +See https://github.com/git-for-windows/git/releases ## Some native console programs don't work when run from Git Bash. How to fix it? From 0078ad0ab905b96bf1b74f513cee004ce8b1b62a Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Mon, 18 Apr 2016 13:42:32 +0100 Subject: [PATCH 188/591] Updated Release Hashes (markdown) --- Release-Hashes.md | 106 ++-------------------------------------------- 1 file changed, 4 insertions(+), 102 deletions(-) diff --git a/Release-Hashes.md b/Release-Hashes.md index 71623175a95067..be804a2f832b0f 100644 --- a/Release-Hashes.md +++ b/Release-Hashes.md @@ -1,103 +1,5 @@ -This page catalogs the release hashes as detailed in the ANNOUNCE mail notifications on the list. - -Insert latest/new announcements just below here (i.e. most recent first). - - -Git for Windows 2.8.1 -===================== -Filename | SHA-256 --------- | ------- -Git-2.8.1-64-bit.exe | 5e5283990cc91d1e9bd0858f8411e7d0afb70ce26e23680252fb4869288c7cfb -Git-2.8.1-32-bit.exe | 17418c2e507243b9c98db161e9e5e8041d958b93ce6078530569b8edaec6b8a4 -PortableGit-2.8.1-64-bit.7z.exe | dc9d971156cf3b6853bc0c1ad0ca76f1d2c24478cca80036919f12fe46acd64e -PortableGit-2.8.1-32-bit.7z.exe | 0b6efaaeb4b127edb3a534261b2c9175bd86ee8683dff6e12ccb194e6abb990e -Git-2.8.1-64-bit.tar.bz2 | 3ebc00b96607174fffb35cf6d96b3b3246aefa504a4bd30375182fea6ab64bde -Git-2.8.1-32-bit.tar.bz2 | 9e754d83190ba154f012d8eaa7433d29517f7c85fff229d4fb62e6418acf8d41 - - - -Git for Windows 2.8.0 -===================== -Filename | SHA-256 --------- | ------- -Git-2.8.0-64-bit.exe | 7c431f31fdb9bb6a8575aec3099d6d4498145fe164f11cc9047c9ad4f885b1db -Git-2.8.0-32-bit.exe | dc27231c05523f76201a5f1c3f826a63872c4e09508b2fe1f84c8d675b986257 -PortableGit-2.8.0-64-bit.7z.exe | a4b199e9ec7b2660b5708a92959ff0eb748bf9bec29f3a05d0bd015f20c06da4 -PortableGit-2.8.0-32-bit.7z.exe | 6ab6e75281dc61a64ea82a79305073ccfe8ee0ba572a2f1ee69e31b2ce94b66c -Git-2.8.0-64-bit.tar.bz2 | b3014123ef9d269e2db811d2e5f116167e6e73fd0c02f64825ea37076d3a136f -Git-2.8.0-32-bit.tar.bz2 | 01b797cb633ad4882136587067f451a50b305ca903826f4394ad092a7f334f2c - - - -Git for Windows 2.7.4 -===================== -Filename | SHA-256 --------- | ------- -Git-2.7.4-64-bit.exe | 1290afb22f2441ce85f8f6f1a94c06768ca470dc18113a83ef6a4cefc16c2381 -Git-2.7.4-32-bit.exe | 49601d5102df249d6f866ecfa1eea68eb5672acc1dbb7e4051099e792f6da5fc -PortableGit-2.7.4-64-bit.7z.exe | d32918f10812b4e60ecbf0524960cff00c8b20d1f0464dab1506d67dbaf8d6cf -PortableGit-2.7.4-32-bit.7z.exe | 4d5a2729b4443ab2d80b899ceebd19ae2cbd17a3b2121178def3590a7dc91987 -Git-2.7.4-64-bit.tar.bz2 | 0075cc2ce01729f99d86dfd1137494883b788991a5a9ee344330b1e377b980d1 -Git-2.7.4-32-bit.tar.bz2 | a4422213576eeac3124f97c5d5624635431ff104168fc1ead639c71831e97e27 - - -Git for Windows 2.7.3 -===================== -Filename | SHA-256 --------- | ------- -Git-2.7.3-64-bit.exe |382d30d38b5c88690864bb46be0a9c5f53b7046e7a6485dbcede602c41cae9a2 -Git-2.7.3-32-bit.exe |e38ddcc2c17390ffec0ca4d5c4fb948b5b4874ea0c522d5180cf2ee7e63f76bd -PortableGit-2.7.3-64-bit.7z.exe |f5b39244869efcfac57c9a9f1d75119de0121bc8aa260d1824dfe5902f9a3f60 -PortableGit-2.7.3-32-bit.7z.exe |82df6b1e8ca8550d7267641e32c6b736f0687e35dc3b772b21914706f13cdea4 -Git-2.7.3-64-bit.tar.bz2 |dd81fe03c83e255382816a5db1427b284288fe21b4f89cbe3b1ff21af8d0ef1c -Git-2.7.3-32-bit.tar.bz2 |3b845331cf91e2a1677ba959d07491c6b04b8bdfc7900236a201d0f8c9863197 - - -Git for Windows 2.7.2 -===================== -Filename | SHA-256 --------- | ------- -Git-2.7.2-64-bit.exe | ec4009b36ce855ab262f999030fff5471de73cf0071202138d395648756c7e8b -Git-2.7.2-32-bit.exe | 7b432c88fa7ced6a89670e9672279e875361651a0abcddbac6fea64a1a168022 -PortableGit-2.7.2-64-bit.7z.exe | 774e18aa40a35ce5f3c0002038937e341c625292c474641c8c936822ef77e949 -PortableGit-2.7.2-32-bit.7z.exe | 26d1e4a290a5741bccc944684a2ffc664676ccc9571e6077d1b8ab40a31fae18 -Git-2.7.2-64-bit.tar.bz2 | b292c68ede2b526db47692ec086b7eea61371bc9548c70e19f25f8625bd87242 -Git-2.7.2-32-bit.tar.bz2 | d9c2cbae64f3c581b497d2adddfa70502ae18436a222d4817c0597c889ee8d09 - - -Git for Windows 2.7.1(2) -======================== -Filename | SHA-256 --------- | ------- -Git-2.7.1.2-64-bit.exe | 956417448441e267a0ca601f47a2cd346e2d09589673060ae25d66628b2abc82 -Git-2.7.1.2-32-bit.exe | be10e98b8c53f92648f8d1c85c7bad4c433aeedcb9d4719588b75030983cd76d -PortableGit-2.7.1.2-64-bit.7z.exe | 92310dec60b0210acbfb31a0165f2628757b8413efcbcea1cfc95b2984a974dd -PortableGit-2.7.1.2-32-bit.7z.exe | 7bf8da2b46f40c98d18a5f9c36e5b90df258936f43a0d230d0f29e0d729e3283 -Git-2.7.1.2-64-bit.tar.bz2 | b3170fc127889f8fa603bc8546c61528869a0a6d2c19bc03de9d96dca2443881 -Git-2.7.1.2-32-bit.tar.bz2 | 4c897917682685194ed9d71fdfafbed721488fe22ecd8f11bfefffe3fec9169a - - -Git for Windows 2.7.1 -===================== -Filename | SHA-256 --------- | ------- -Git-2.7.1-64-bit.exe | ab3eee9558f5bedffbe5518edcd84dbade813a013470d7640285a9c9c263be5a -Git-2.7.1-32-bit.exe | 687e58df471bf88996a3ba619d25ccaaecd7243cbdb291f028abce68e8620569 -PortableGit-2.7.1-64-bit.7z.exe | 93b56b61973dce5b56127796b714cd29bd4777cce54e09e497dc1d0b2bb6057e -PortableGit-2.7.1-32-bit.7z.exe | f65ac7104a5b5c9d9bfa5b86df90acfe140ef5415ee8126daab050a157264cc7 -Git-2.7.1-64-bit.tar.bz2 | 2ab050864eaf60b158868a5a96ec5a2f2072a446a04dae9d290c4377871bb75f -Git-2.7.1-32-bit.tar.bz2 | a7b5d4d94b89e5eac5603c45ebbc28cb377f5835f6b3416f255972c77bd5226b - - - -Git for Windows 2.7.0(2) -======================== -Filename | SHA-256 --------- | ------- -Git-2.7.0.2-64-bit.exe | c9f0ba628d79886427e05b6b2833f65630ccfc49ecceaab7cff0c6723d1d6e47 -Git-2.7.0.2-32-bit.exe | 8f14d50a1950264a7fd53128a81884f5757ca2b645e092ce81122993433657f8 -PortableGit-2.7.0.2-64-bit.7z.exe | aa29dcfffda49bde58c84d34cec8e38f4ea85d97c5bb789a56e00ab86a60de5e -PortableGit-2.7.0.2-32-bit.7z.exe | b5af00c5bcffd67c57beb9ce379a8080e44a2f9fe05650a8d7d460382832cbea -Git-2.7.0.2-64-bit.tar.bz2 | 9ed65a54b2586059a53ce64a57d2faa99386b282dd427a4a7e5474feb00d0851 -Git-2.7.0.2-32-bit.tar.bz2 | a9c2daf66ed9864146945e5e2e0970a13cd9140b0fb0327a668e2550a7cc24e8 +Release hashes are detailed in: +* the ANNOUNCE mail notifications on the list and +* on the https://github.com/git-for-windows/git/releases page. +The list can be read and joined at https://groups.google.com/forum/#!forum/git-for-windows \ No newline at end of file From 28e33126309f53173cb8a786ff881f99c2d53a9e Mon Sep 17 00:00:00 2001 From: Adric Norris Date: Mon, 18 Apr 2016 20:27:05 -0500 Subject: [PATCH 189/591] Update instructions for officially merged ssh-pageant implementation --- OpenSSH-Integration-with-Pageant.md | 75 ++++++++++++++++------------- 1 file changed, 42 insertions(+), 33 deletions(-) diff --git a/OpenSSH-Integration-with-Pageant.md b/OpenSSH-Integration-with-Pageant.md index 225bf57d9ad30f..7f161be436d7d4 100644 --- a/OpenSSH-Integration-with-Pageant.md +++ b/OpenSSH-Integration-with-Pageant.md @@ -1,58 +1,67 @@ # OpenSSH Integration with Pageant -For some users, it may be desirable to tie OpenSSH in to the PuTTY authentication agent (Pageant). This allows you to leverage OpenSSH for remote repository access, which tends to be the most reliable choice within the specific context of Git for Windows (Git), while using a single keystore for your computer as a whole. +For some users, it may be desirable to tie OpenSSH in to the PuTTY authentication agent (Pageant) using [ssh\-pageant](https://github.com/cuviper/ssh-pageant). This is a drop-in replacement for _ssh\-agent_, which simply builds a connection between OpenSSH and Pageant for key-based authentication. The tool makes it easy to leverage OpenSSH for remote repository access, which tends to be the most reliable choice within the specific context of Git for Windows (Git), without the need to run multiple agents which don't interoperate. -While the capability is not currently integrated into Git, it's straightforward to accomplish using [ssh\-pageant](https://github.com/cuviper/ssh-pageant). This is a drop-in replacement for ssh-agent, which simply builds a connection between OpenSSH and Pageant for key-based authentication. +This functionality was integrated after the release of Git 2.8.1, and is expected to become available with the following version. -## Limitations +## Starting ssh\-pageant Manually from Git Bash -Since Git bundles OpenSSH internally, and needs a msys2\-specific build of ssh\-pageant, you probably need to use Git Bash (rather than Git CMD) in order to make use of this functionality. +If you always use Git from within Git Bash, then the most straightforward approach is to have it launch _ssh\-pageant_ on your behalf. Simply create/edit your _$HOME/.bash_profile_ (or _$HOME/.profile_, if you prefer), and add the following. -## Obtaining ssh\-pageant + # ssh-pageant allows use of the PuTTY authentication agent (Pageant) + SSH_PAGEANT="$(command -v ssh-pageant)" + if [ -x "$SSH_PAGEANT" ]; then + eval $("$SSH_PAGEANT" -qra "${SSH_AUTH_SOCK:-${TEMP:-/tmp}/.ssh-pageant-$USERNAME}") + fi + unset SSH_PAGEANT -### End User (non\-SDK) Git Installation +The `-qra "${TEMP:-/tmp}/.ssh-pageant"` construct is equivalent to the `-q -r -a filename` options. In this context it means: -For a normal (non-SDK) installation of Git, the first step is to download the ssh-pageant package from either the [32\-bit](http://repo.msys2.org/msys/i686/) or [64\-bit](http://repo.msys2.org/msys/x86_64/) msys2 repository... be sure to match the bit-level of your Git software. The specific filename may vary, but should match the pattern of "ssh\-pageant\-git\-\*.pkg.tar.xz". +* **\-a filename** \-\- Bind to a specific socket file (creating it if necessary) +* **\-r** \-\- Allow reuse of an existing socket file (exit without error if an existing _ssh\-pageant/ssh\-agent_ process is using it) +* **\-q** \-\- Quiet mode (don't echo the PID, if starting a new ssh\-pageant process) -Once the file has been successfully downloaded, the next step is to decompress it. This can be done using *7z* from within Git Bash. +By specifying the socket name (defaulting to `$SSH_AUTH_SOCK`, if set) along with the reuse option, we ensure that only a single running copy of ssh\-pageant (per user) is required. Otherwise a separate incarnation would be launched every time Git Bash is invoked. - 7z e ssh-pageant-git-*.pkg.tar.xz +### Verify ssh\-pageant Functionality -This should result in a second file with the same name, minus the ".xz" extension. We can now extract *ssh\-pageant.exe* using *tar*. +Now start a new Git Bash session, or source the profile edited just above, and run the `ssh-add -l` command. If all is well, and Pageant is running (with one or more keys loaded), you should see something similar to the following. - tar xf ssh-pageant-git-*.pkg.tar --strip=2 usr/bin/ssh-pageant.exe + $ ssh-add -l + 4096 SHA256:XjN/glikgdBoBclg4EaN8sJ/ibrxTq7zVydpkUwANzk Heinz Doofenshmirtz (RSA) -Finally, we need to copy the executable from the current directory to a location outside our Git installation, to ensure that it won't get clobbered during upgrades. Typically *$HOME/bin* is used for this purpose. +## Starting ssh\-pageant Automatically at Logon - mkdir $HOME/bin - mv ssh-pageant.exe $HOME/bin/ +If you use Git from Git CMD, or directly from the Windows command prompt, then you'll probably want to ensure that _ssh\-pageant\_ is launched automatically at logon time. The _start\-ssh\-pageant.cmd_ script is provided for this purpose, which resides in the **cmd** subdirectory of your Git installation. -### Git SDK Installation +### Setting the Environment -Having the full SDK available simplifies the process, as you just need to run the following command to install the *ssh\-pageant* package. +Unlike the Git Bash case above, this scenario **requires** the _SSH\_AUTH\_SOCK_ environment variable to be set before running the script... otherwise it will simply exit without performing any action. This is normally configured as a persistent **USER** variable, with the value specifying the desired socket file path in Unix/MSYS2 format. - pacman -S ssh-pageant +#### Windows 7 -## Starting ssh\-pageant Automatically +Launch the Control Panel, and then select _System_ followed by _Advanced system settings_. Click on the _Environment Variables_ button, and finally _New..._ in the _User variables_ (**not** _System variables_) section. Enter **SSH_AUTH_SOCK** for _Variable name_ and **/tmp/.ssh-pageant-%USERNAME%** for _Variable value_, then click _OK_. -Now that the ssh\-pageant utility is present, it's a simple matter for Git Bash to start it automatically. Just create/edit your *$HOME/.bash_profile* (or *$HOME/.profile*, if you prefer), and add the following. +Now launch a new Git CMD or Windows command prompt (pre-existing sessions won't see the new variable), and enter the command `set SSH_AUTH_SOCK`. If all went according to plan, you should see something similar to the following. - # ssh-pageant allows use of the PuTTY authentication agent (Pageant) - SSH_PAGEANT="$(PATH=/usr/bin:$HOME/bin command -v ssh-pageant)" - if [ -z "$SSH_AUTH_SOCK" -a -x "$SSH_PAGEANT" ]; then - eval $("$SSH_PAGEANT" -qra "${TEMP:-/tmp}/.ssh-pageant-$USERNAME") - fi - unset SSH_PAGEANT + C:\Users\heinz.doofenshmirtz> set SSH_AUTH_SOCK + SSH_AUTH_SOCK=/tmp/.ssh-pageant-heinz.doofenshmirtz -The `-qra "${TEMP:-/tmp}/.ssh-pageant"` portion is equivalent to the `-q -r -a filename` options. In this context it means: +### Launch ssh\-pageant -* **\-a filename** \-\- Bind to a specific socket file (creating it if necessary) -* **\-r** \-\- Allow reuse of an existing socket file -* **\-q** \-\- Quiet mode +At this point you should run _start\-ssh\-pageant.cmd_ manually, in order to verify that the agent starts successfully. Assuming that Git is installed into _C:\Program Files\Git_, this should look something like: -By specifying the socket name along with the reuse option, we ensure that only a single running copy of ssh\-pageant is required. Otherwise a separate incarnation would be launched every time Git Bash gets invoked. + C:\Program Files\Git\cmd> start-ssh-pageant + Starting ssh-pageant... + SSH_AUTH_SOCK='/tmp/.ssh-pageant-heinz.doofenshmirtz' + SSH_PAGEANT_PID=11444 -Now start a new Git Bash session, or source the profile edited just above, and run the `ssh-add -l` command. If all is well, and Pageant is running (with keys loaded), you should see something similar to the following. +Assuming that the relevant keys have been loaded into Pageant, you should now be able to perform Git operations which rely upon them using OpenSSH without being prompted for the passphrase. - $ ssh-add -l - 4096 SHA256:XjN/glikgdBoBclg4EaN8sJ/ibrxTq7zVydpkUwANzk Heinz Doofenshmirtz (RSA) +### Configure Automatic Startup + +The most common approach is to create a shortcut pointing to _start\-ssh\-pageant.cmd_, and place it in your startup folder (_Start Menu_ / _Programs_ / _Startup_). Once in place, it should be launched automatically when you logon to Windows and be available to all Git processes. + +## Security Considerations + +Since _ssh\-pageant_ (like _ssh\-agent_) is intended to bypass the requirement to repeatedly enter your private key password, it's imperative that its socket file be private in order to use it safely. In other words, you want to be **extremely** careful on multi-user systems to ensure that the **SSH_AUTH_SOCK** file -- and preferably the directory which includes it -- isn't accessible to anyone else. For a normal MSYS2 configuration (which includes Git) this shouldn't be an issue, as _/tmp_ is normally mapped to a private location under your Windows user profile. \ No newline at end of file From c191fc4f6ce9506706e6a986de2bb0e1387d61b0 Mon Sep 17 00:00:00 2001 From: Todd Weed Partridge Date: Tue, 19 Apr 2016 11:51:53 -0400 Subject: [PATCH 190/591] Added ssh-add file path as I had an instance where it was necessary (probably better to be safe and define it rather than let it assume). --- Auto-launching-ssh-agent-when-git-starts.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/Auto-launching-ssh-agent-when-git-starts.md b/Auto-launching-ssh-agent-when-git-starts.md index 13a30dd8271533..d062d5feff4aea 100644 --- a/Auto-launching-ssh-agent-when-git-starts.md +++ b/Auto-launching-ssh-agent-when-git-starts.md @@ -19,9 +19,9 @@ To launch, put in `~/.profile` or `~/.bashrc`: agent_run_state=$(ssh-add -l >| /dev/null 2>&1; echo $?) if [ $agent_run_state = 2 ]; then eval $(ssh-agent -s) - ssh-add + ssh-add ~/.ssh/id_rsa elif [ $agent_run_state = 1 ]; then - ssh-add + ssh-add ~/.ssh/id_rsa fi ``` From c112bb03307e63dc83d4a563a6193ea3da880c53 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Fri, 22 Apr 2016 16:46:01 +0200 Subject: [PATCH 191/591] Mention how to rewrite the branch of a Pull Request --- How-to-participate.md | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/How-to-participate.md b/How-to-participate.md index 6695206a54b373..2642bf7ed1ee13 100644 --- a/How-to-participate.md +++ b/How-to-participate.md @@ -14,4 +14,6 @@ Download [the SDK](http://git-for-windows.github.io/#download-sdk) and build Git Please also sign off your work, as [asked by the Git project](https://github.com/git/git/blob/v2.3.5/Documentation/SubmittingPatches#L234-L286) -After that, submit a Pull Request. \ No newline at end of file +After that, submit a Pull Request. + +Sometimes there are good suggestions how to improve the patches in a Pull Request. When that happens, just [rewrite and force-push the branch](https://robots.thoughtbot.com/git-interactive-rebase-squash-amend-rewriting-history). \ No newline at end of file From 0fb5cd2d2d1ee66e6fd063bd1da9ea9d20dbf06c Mon Sep 17 00:00:00 2001 From: Adric Norris Date: Wed, 27 Apr 2016 12:48:31 -0500 Subject: [PATCH 192/591] Updated OpenSSH Integration with Pageant (markdown) --- OpenSSH-Integration-with-Pageant.md | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/OpenSSH-Integration-with-Pageant.md b/OpenSSH-Integration-with-Pageant.md index 7f161be436d7d4..44fdc0a2e13d2e 100644 --- a/OpenSSH-Integration-with-Pageant.md +++ b/OpenSSH-Integration-with-Pageant.md @@ -62,6 +62,15 @@ Assuming that the relevant keys have been loaded into Pageant, you should now be The most common approach is to create a shortcut pointing to _start\-ssh\-pageant.cmd_, and place it in your startup folder (_Start Menu_ / _Programs_ / _Startup_). Once in place, it should be launched automatically when you logon to Windows and be available to all Git processes. +#### Windows 7 + +1. Click the *Start* button, right click on *All Programs*, and select *Open* +2. Navigate into the *Programs* folder, followed by *Startup* +3. Right-click on an empty spot within *Startup*, and select **New / Shortcut** +4. Click *Browse*, navigate to the *cmd* folder underneath your Git installation, and select **start-ssh-pageant.cmd**. Click *OK*. +5. Click *Next* +6. Enter an alternate name for the shortcut, if desired, and click *Finish* + ## Security Considerations Since _ssh\-pageant_ (like _ssh\-agent_) is intended to bypass the requirement to repeatedly enter your private key password, it's imperative that its socket file be private in order to use it safely. In other words, you want to be **extremely** careful on multi-user systems to ensure that the **SSH_AUTH_SOCK** file -- and preferably the directory which includes it -- isn't accessible to anyone else. For a normal MSYS2 configuration (which includes Git) this shouldn't be an issue, as _/tmp_ is normally mapped to a private location under your Windows user profile. \ No newline at end of file From 99753fd5616270ed7cb4532cdaec65924a125be8 Mon Sep 17 00:00:00 2001 From: jasonnian1978 Date: Thu, 28 Apr 2016 10:11:02 +0800 Subject: [PATCH 193/591] Updated Home (markdown) --- Home.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Home.md b/Home.md index b5649f502b9548..7227bdbee69d6f 100644 --- a/Home.md +++ b/Home.md @@ -1,4 +1,4 @@ -# Introduction +# # Introduction The _Git for Windows_ wiki. It looks more technical than [our home page](https://git-for-windows.github.io/) because it is the place where *you* [can contribute](https://github.com/git-for-windows/git/wiki/How-to-participate) to the documentation about _Git for Windows_. ## About From eb35b990be88ff12826cb6ffa14b00f761b217f6 Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Mon, 2 May 2016 23:43:54 +0100 Subject: [PATCH 194/591] A page which starts to capture information for VS users and potential G4W devs --- Visual-Studio-and-MSVC-compilation.md | 36 +++++++++++++++++++++++++++ 1 file changed, 36 insertions(+) create mode 100644 Visual-Studio-and-MSVC-compilation.md diff --git a/Visual-Studio-and-MSVC-compilation.md b/Visual-Studio-and-MSVC-compilation.md new file mode 100644 index 00000000000000..3a1267ae74e5c0 --- /dev/null +++ b/Visual-Studio-and-MSVC-compilation.md @@ -0,0 +1,36 @@ +This page curates tidbits regarding the use of Microsoft tools when editing or creating a personal version of Git. + +You can comple Git using the MSVC compiler, or create a Visual Studio project for Git. + +As Git upstream develops, the MSVC and VS projects can get left behind, so this page is to help folk keep up to date, keep testing, reporting breakages, and hopefully offering fixes or at least a bit of analysis using their favourite tool (you're here, so it must be..) + +Current Work +------------ + +The aim is to be at least backward compatible to VS2008. The prior tools targeted that version, and MS provides upgrade/conversion facilities for newer versions. Back then parts of the tools were in a separate repo [MSYSGIT](https://github.com/msysgit/msysgit). Those parts have been transfered into the Git-for-Windows repository (or forks there-of) see https://github.com/git-for-windows/git/pull/256 + +You can now (#256) create a VS project file using the `msvc-build --vs` command in the contrib section. This will compile however there are a couple of link failures which need the right libraries to be automatically linked in the right places. + +The main remaining issue is to include the auto post-build steps to install the sucessful compilation; and keep up with everything else.. + +Acronyms +-------- + +###MSVC (Micro Soft Visual studio Compiler) +MSVC is used to refer to Microsoft's compiler that lies beneath the VS IDE. Exactly what is compiled, and where it is targeted depends on the normal pre-processor #defines and #includes. MSVC already includes a number of pre-defined windows library functions. + +###VSyyyy IDE (Visual Studio (some year) Integrated Development Environment +The full windows treatment of the graphics front end which allows the navigation of your source code within its own project. + +###GIT_WINDOWS_NATIVE +This is the environment variable used to indicate that this is not a CYGWIN compilation, but that we are in Windows land. + +###WIN32_LEAN_AND_MEAN +see https://blogs.msdn.microsoft.com/oldnewthing/20091130-00/?p=15863 This controls what additional libraries windows will import, particularly winsock which would otherwise be multiply defined. + +###MSYS2 +part of the (typically needed) operating stack for getting *nix / POSIX code working. see [The-difference-between-MINGW-and-MSYS2](https://github.com/git-for-windows/git/wiki/The-difference-between-MINGW-and-MSYS2) + +###MinGW +part of the (typically needed) operating stack for getting *nix / POSIX code working. see [The-difference-between-MINGW-and-MSYS2](https://github.com/git-for-windows/git/wiki/The-difference-between-MINGW-and-MSYS2) + From 412c0532da5070a12d434ed4229f01c9282fcba5 Mon Sep 17 00:00:00 2001 From: Adric Norris Date: Tue, 3 May 2016 13:43:23 -0500 Subject: [PATCH 195/591] Indicate which release ssh-pageant integration landed in --- OpenSSH-Integration-with-Pageant.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/OpenSSH-Integration-with-Pageant.md b/OpenSSH-Integration-with-Pageant.md index 44fdc0a2e13d2e..6594e2f2ebcdd6 100644 --- a/OpenSSH-Integration-with-Pageant.md +++ b/OpenSSH-Integration-with-Pageant.md @@ -2,7 +2,7 @@ For some users, it may be desirable to tie OpenSSH in to the PuTTY authentication agent (Pageant) using [ssh\-pageant](https://github.com/cuviper/ssh-pageant). This is a drop-in replacement for _ssh\-agent_, which simply builds a connection between OpenSSH and Pageant for key-based authentication. The tool makes it easy to leverage OpenSSH for remote repository access, which tends to be the most reliable choice within the specific context of Git for Windows (Git), without the need to run multiple agents which don't interoperate. -This functionality was integrated after the release of Git 2.8.1, and is expected to become available with the following version. +This functionality became available with the release of Git 2.8.2. ## Starting ssh\-pageant Manually from Git Bash From a1427289877d60886dcb95953d71923b1dad54a8 Mon Sep 17 00:00:00 2001 From: Adric Norris Date: Tue, 3 May 2016 13:49:27 -0500 Subject: [PATCH 196/591] Note possible environment-variable conflict when running multiple Unix-like environments --- OpenSSH-Integration-with-Pageant.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/OpenSSH-Integration-with-Pageant.md b/OpenSSH-Integration-with-Pageant.md index 6594e2f2ebcdd6..73a5dae4284c0f 100644 --- a/OpenSSH-Integration-with-Pageant.md +++ b/OpenSSH-Integration-with-Pageant.md @@ -38,6 +38,8 @@ If you use Git from Git CMD, or directly from the Windows command prompt, then y Unlike the Git Bash case above, this scenario **requires** the _SSH\_AUTH\_SOCK_ environment variable to be set before running the script... otherwise it will simply exit without performing any action. This is normally configured as a persistent **USER** variable, with the value specifying the desired socket file path in Unix/MSYS2 format. +NOTE: Since there can only be a single global variable of a given name, this approach may or may not cause conflicts if you have multiple environments which utilize the SSH_AUTH_SOCK setting. Running Git alongside of Cygwin, for example. + #### Windows 7 Launch the Control Panel, and then select _System_ followed by _Advanced system settings_. Click on the _Environment Variables_ button, and finally _New..._ in the _User variables_ (**not** _System variables_) section. Enter **SSH_AUTH_SOCK** for _Variable name_ and **/tmp/.ssh-pageant-%USERNAME%** for _Variable value_, then click _OK_. From ffbab305c1635414a324ca48a2967cb1de359672 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Wed, 11 May 2016 08:25:37 +0200 Subject: [PATCH 197/591] mention that symlinks are absolute --- Symbolic-Links.md | 1 + 1 file changed, 1 insertion(+) diff --git a/Symbolic-Links.md b/Symbolic-Links.md index 62ae823b641968..ed592a5ec5154b 100644 --- a/Symbolic-Links.md +++ b/Symbolic-Links.md @@ -7,6 +7,7 @@ Starting with Windows Vista, there is support for symbolic links. These are not - Symbolic links are only available on Windows Vista and later, most notably not on XP - You need the `SeCreateSymbolicLinkPrivilege` privilege, which is by default assigned only to Administrators but can be assigned to normal users using Local Security Policy (or via Active Directory). Home Editions of Windows Vista and Windows 7 do not have Local Security Policy, but the freely available Polsedit (http://www.southsoftware.com) can be used on these editions. Note that regardless of privilege assignment, members of the Administrators group will also require UAC elevation (see the full details in *Access Token Changes* just above https://msdn.microsoft.com/en-us/library/bb530410.aspx#vistauac_topic4) - Symbolic links on remote filesystems are disabled by default (call `fsutil behavior query SymlinkEvaluation` to find out) +- Symlinks on Windows are always absolute, which does not make much sense in Git’s context: if you version-control symlinks, they typically need to point back into the same working tree, i.e. they are relative. The way we handle this in Git for Windows means that you cannot blindly copy/move your code and expect it to work properly, if it contains symlinks. - Symbolic links will only work on NTFS, not on FAT - Windows' symbolic links are typed: they need to know whether they point to a directory or to a file (for this reason, Git will update the type when it finds that it is wrong) - Many programs do not understand symbolic links From 55fd433e768f55a3e605452c3a86ce68765ec0ae Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Thu, 12 May 2016 16:19:20 +0200 Subject: [PATCH 198/591] Symbolic links (as opposed to directory junction points) *can* be relative, as pointed out by Neal Christiansen --- Symbolic-Links.md | 1 - 1 file changed, 1 deletion(-) diff --git a/Symbolic-Links.md b/Symbolic-Links.md index ed592a5ec5154b..62ae823b641968 100644 --- a/Symbolic-Links.md +++ b/Symbolic-Links.md @@ -7,7 +7,6 @@ Starting with Windows Vista, there is support for symbolic links. These are not - Symbolic links are only available on Windows Vista and later, most notably not on XP - You need the `SeCreateSymbolicLinkPrivilege` privilege, which is by default assigned only to Administrators but can be assigned to normal users using Local Security Policy (or via Active Directory). Home Editions of Windows Vista and Windows 7 do not have Local Security Policy, but the freely available Polsedit (http://www.southsoftware.com) can be used on these editions. Note that regardless of privilege assignment, members of the Administrators group will also require UAC elevation (see the full details in *Access Token Changes* just above https://msdn.microsoft.com/en-us/library/bb530410.aspx#vistauac_topic4) - Symbolic links on remote filesystems are disabled by default (call `fsutil behavior query SymlinkEvaluation` to find out) -- Symlinks on Windows are always absolute, which does not make much sense in Git’s context: if you version-control symlinks, they typically need to point back into the same working tree, i.e. they are relative. The way we handle this in Git for Windows means that you cannot blindly copy/move your code and expect it to work properly, if it contains symlinks. - Symbolic links will only work on NTFS, not on FAT - Windows' symbolic links are typed: they need to know whether they point to a directory or to a file (for this reason, Git will update the type when it finds that it is wrong) - Many programs do not understand symbolic links From 627bbce026c92cb37be91da07d940899211448a8 Mon Sep 17 00:00:00 2001 From: Florian Kaiser Date: Wed, 18 May 2016 12:30:18 +0200 Subject: [PATCH 199/591] Improve formatting --- Home.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Home.md b/Home.md index 7227bdbee69d6f..b5649f502b9548 100644 --- a/Home.md +++ b/Home.md @@ -1,4 +1,4 @@ -# # Introduction +# Introduction The _Git for Windows_ wiki. It looks more technical than [our home page](https://git-for-windows.github.io/) because it is the place where *you* [can contribute](https://github.com/git-for-windows/git/wiki/How-to-participate) to the documentation about _Git for Windows_. ## About From 3a8be389b048fa65bb41e278d560791eafafa6e2 Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Sat, 18 Jun 2016 14:14:30 +0100 Subject: [PATCH 200/591] guide where the G4W release notes are located. --- FAQ.md | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/FAQ.md b/FAQ.md index f0acbbccc11cad..9b5e22d0c0bc78 100644 --- a/FAQ.md +++ b/FAQ.md @@ -8,9 +8,11 @@ This depends on how you installed *Git for Windows*. The bundle installation req For advanced users working with the *Git for Windows* SDK `pacman` is available as a package manager. See [Package management](Package-management) -## How do I check the release hash +## How do I check the release hash and release notes -See https://github.com/git-for-windows/git/releases +For hashes see https://github.com/git-for-windows/git/releases + +For (G4W) release notes see the [build-extra repo](https://github.com/git-for-windows/build-extra/blob/master/ReleaseNotes.md) or the top level of your installation (e.g. C:\Program Files\Git\ReleaseNotes.html). ## Some native console programs don't work when run from Git Bash. How to fix it? From 6293e4b3063c8c71091f2ab0e6236618de401a19 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Wed, 22 Jun 2016 12:39:20 +0200 Subject: [PATCH 201/591] Add a new page documenting how to write regression tests Jeff Hostetler asked for this information, and it makes sense to write this up and I wanted to do this for such a long time already, anyway. Signed-off-by: Johannes Schindelin --- Adding-regression-tests.md | 44 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 44 insertions(+) create mode 100644 Adding-regression-tests.md diff --git a/Adding-regression-tests.md b/Adding-regression-tests.md new file mode 100644 index 00000000000000..9210aa727ffffe --- /dev/null +++ b/Adding-regression-tests.md @@ -0,0 +1,44 @@ +Git comes with an extensive regression test suite. It lives in the [`t/` subdirectory](https://github.com/git/git/tree/master/t) of the source code repository and is organized into test scripts, e.g. `t8002-blame.sh`, which contain multiple test cases. The test scripts themselves are shell scripts. + +The best documentation how to add tests is the test suite itself, by example. + +# Adding test cases + +You will want to add test cases either to demonstrate bugs, or to ensure that certain operations work as expected (e.g. when you just implemented such an operation or fixed a bug). + +In the most common case, you will want to add your test case to an existing test script. Use the file name and `git grep`'s output as an indicator which script is the best one to which to add your test case. + +Each test case is written in the form + +```sh +test_expect_success 'title' ' + # Here come the shell script statements +' +``` + +If you want to demonstrate a breakage, use `test_expect_failure` instead, and write the rest of the test case as if the bug was fixed, i.e. the way you want to see it succeed. + +Inside the script part, you need to connect everything into an ‘&&’ chain, i.e. + +```sh + test_commit this-will-write-a-file-and-commit && + echo New file >new-file.txt && + git status --porcelain --verbose --verbose >output && + grep new-file.txt output +``` + +If you need to test anything Windows-specific, you can put `MINGW` before the case’s title, as a prerequisite. Likewise, you can use `!MINGW` to test only on non-Windows. + +Every script creates a test repository with a test working tree in a new directory called `t/trash directory.`, e.g. `t/trash directory.t8002-blame/`. + +Traditionally, the first “test case” is the setup, where you set up files and commits common to multiple test cases in the same script. + +There are a bunch of really useful functions for use in test scripts, e.g. `test_commit`, which not only abbreviates the common “write a file, add it, commit it, tag the commit” stanza, but also increments the timestamp from a fixed first timestamp, so that the commits are reproducible (read: so you can reliably debug even if the bug depends on some side effect of some compression or some such). You will find a comprehensive list in [`t/README`](https://github.com/git/git/blob/master/t/README) under the “Test harness library” heading. + +There are also a bunch of useful test helpers in `t/helper/` (automatically added to the `PATH`) e.g. `test-chmtime`. If you need to test native functions, you can introduce a new test helper, or piggy-back onto an existing one. + +As you will most likely add a test case to an existing script, you can use whatever the test repository’s current state is. To find out, just run the script with the `-d` option, which will leave the trash directory behind instead of removing it after a successful conclusion of the script: `cd t && sh t8002-blame.sh -d`. + +In addition to `-d`, I found the options `-i` (stop upon first failing test case), `-x` (show the tests’ commands before they are executed) and `-v` (show the entire output instead of suppressing it) useful. + +If you want to use `-x`, it is best to run through bash instead of sh, as some tests require a bash feature where the trace is printed to a different file descriptor than stderr, although in Git for Windows’ SDK, sh still refers to bash, so it is the same. From 354b93b32f5744c2be0a4b0a34202128e6ae7017 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Fri, 22 Jul 2016 09:45:25 +0200 Subject: [PATCH 202/591] Add a note about safe Git for Windows versions Signed-off-by: Johannes Schindelin --- FAQ.md | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/FAQ.md b/FAQ.md index 9b5e22d0c0bc78..470c6cbeaafb06 100644 --- a/FAQ.md +++ b/FAQ.md @@ -1,3 +1,9 @@ +## Should I upgrade to a newer Git for Windows version? + +In general, yes: it is a good idea to stay up-to-date. + +If you have a version older than 2.7.4, it is *highly* advisable to upgrade. These versions fixed critical bugs, therefore sticking with older Git for Windows versions makes you vulnerable: 2.7.4, 2.6.1, 2.5.2, 1.9.5-preview20150319, and 1.9.5-preview20141217. + ## What is the relationship between *Git for Windows* and *msysGit*? *Git for Windows* used to be developed using the development environment called "msysGit", but roughly coinciding with Git 2.1, msysGit was superseded by a new development environment: the [Git for Windows SDK](https://github.com/git-for-windows/build-extra/releases). From e34ab3bb394cd018c2b092a5d9808654a013b5b4 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Tue, 26 Jul 2016 17:00:09 +0200 Subject: [PATCH 203/591] Forgot to mention 2.7.0, which fixed an important bug, too. --- FAQ.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/FAQ.md b/FAQ.md index 470c6cbeaafb06..bdb302de0eaaae 100644 --- a/FAQ.md +++ b/FAQ.md @@ -2,7 +2,7 @@ In general, yes: it is a good idea to stay up-to-date. -If you have a version older than 2.7.4, it is *highly* advisable to upgrade. These versions fixed critical bugs, therefore sticking with older Git for Windows versions makes you vulnerable: 2.7.4, 2.6.1, 2.5.2, 1.9.5-preview20150319, and 1.9.5-preview20141217. +If you have a version older than 2.7.4, it is *highly* advisable to upgrade. These versions fixed critical bugs, therefore sticking with older Git for Windows versions makes you vulnerable: 2.7.4, 2.7.0, 2.6.1, 2.5.2, 1.9.5-preview20150319, and 1.9.5-preview20141217. ## What is the relationship between *Git for Windows* and *msysGit*? From 23f25fbefe34208f5dadbdd26cac314917c2d36c Mon Sep 17 00:00:00 2001 From: Adric Norris Date: Mon, 1 Aug 2016 11:25:51 -0500 Subject: [PATCH 204/591] fixed a minor formatting error --- OpenSSH-Integration-with-Pageant.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/OpenSSH-Integration-with-Pageant.md b/OpenSSH-Integration-with-Pageant.md index 73a5dae4284c0f..06fbb63e50ab9f 100644 --- a/OpenSSH-Integration-with-Pageant.md +++ b/OpenSSH-Integration-with-Pageant.md @@ -32,7 +32,7 @@ Now start a new Git Bash session, or source the profile edited just above, and r ## Starting ssh\-pageant Automatically at Logon -If you use Git from Git CMD, or directly from the Windows command prompt, then you'll probably want to ensure that _ssh\-pageant\_ is launched automatically at logon time. The _start\-ssh\-pageant.cmd_ script is provided for this purpose, which resides in the **cmd** subdirectory of your Git installation. +If you use Git from Git CMD, or directly from the Windows command prompt, then you'll probably want to ensure that _ssh\-pageant_ is launched automatically at logon time. The _start\-ssh\-pageant.cmd_ script is provided for this purpose, which resides in the **cmd** subdirectory of your Git installation. ### Setting the Environment From 5911a100031d57b0bc30c87afd1ec29e2118dcbf Mon Sep 17 00:00:00 2001 From: woest85 Date: Thu, 1 Sep 2016 13:38:42 +0200 Subject: [PATCH 205/591] Updated FAQ (markdown) --- FAQ.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/FAQ.md b/FAQ.md index bdb302de0eaaae..29e0521bd4dff8 100644 --- a/FAQ.md +++ b/FAQ.md @@ -50,7 +50,7 @@ Some DSA keys are not considered secure anymore by OpenSSH 7. Adding "PubkeyAcce ## Switch locale for git-bash launcher (of Git for Windows SDK) Some developers want to start git-bash (of Git for Windows SDK) with a different language. -To achive this in windows following command could be placed inside the launcher: +To achieve this in windows following command could be placed inside the launcher: C:\Windows\System32\cmd.exe /c "set LANG=en_GB && start C:\git-sdk-64\git-bash.exe && exit" Replace "en_GB" with your preferred locale. From 959fb0c6d518d89b1851d14dccefa5bd255169d2 Mon Sep 17 00:00:00 2001 From: Stefan Naewe Date: Thu, 8 Sep 2016 21:22:41 +0200 Subject: [PATCH 206/591] Add not about inactive CI servers --- Continuous-Integration-(CI).md | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/Continuous-Integration-(CI).md b/Continuous-Integration-(CI).md index 57c00e4aa2f81c..e457b362028ac3 100644 --- a/Continuous-Integration-(CI).md +++ b/Continuous-Integration-(CI).md @@ -1,3 +1,8 @@ +# _Attention !_ # +_As of 2016-09-08 the CI services mentioned blow are no longer active. Dscho is currently working on CI based on Visual Studio Team Services. No ETA yet, though..._ + +*** + ## Foreword We have a [public Jenkins CI server](https://dscho.cloudapp.net/) running on Windows Server 2012 R2 in [Microsoft Azure](http://azure.microsoft.com/). Anonymous users are able to see the job configurations, but not to edit them. From 73af1a0ca3ca1399c5c2170e2e09ce771e0da226 Mon Sep 17 00:00:00 2001 From: Stefan Naewe Date: Fri, 9 Sep 2016 09:55:12 +0200 Subject: [PATCH 207/591] typofix --- Continuous-Integration-(CI).md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Continuous-Integration-(CI).md b/Continuous-Integration-(CI).md index e457b362028ac3..503776de4f3be7 100644 --- a/Continuous-Integration-(CI).md +++ b/Continuous-Integration-(CI).md @@ -1,5 +1,5 @@ # _Attention !_ # -_As of 2016-09-08 the CI services mentioned blow are no longer active. Dscho is currently working on CI based on Visual Studio Team Services. No ETA yet, though..._ +_As of 2016-09-08 the CI services mentioned below are no longer active. Dscho is currently working on CI based on Visual Studio Team Services. No ETA yet, though..._ *** From bbe577e1bf9b6ea156885c03e90dfe3c82c18c6b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=EB=A7=88=EB=88=84=EC=97=98?= Date: Thu, 6 Oct 2016 11:50:44 +0200 Subject: [PATCH 208/591] Added section about supported windows version. Thanks to https://www.cygwin.com/ for the text. --- FAQ.md | 16 ++++++++++++---- 1 file changed, 12 insertions(+), 4 deletions(-) diff --git a/FAQ.md b/FAQ.md index 29e0521bd4dff8..402d71e95c4dd1 100644 --- a/FAQ.md +++ b/FAQ.md @@ -1,3 +1,14 @@ +## Which versions of Windows are supported? + +Git for Windows currently works with all recent, commercially released x86 32 bit and 64 bit versions of Windows, starting with Windows Vista. + +*** + +NOTE: Git for Windows version [2.10.0](https://github.com/git-for-windows/git/releases/tag/v2.10.0.windows.1) was the last version supporting Windows XP and Server 2003. + +*** + + ## Should I upgrade to a newer Git for Windows version? In general, yes: it is a good idea to stay up-to-date. @@ -52,7 +63,4 @@ Some DSA keys are not considered secure anymore by OpenSSH 7. Adding "PubkeyAcce Some developers want to start git-bash (of Git for Windows SDK) with a different language. To achieve this in windows following command could be placed inside the launcher: C:\Windows\System32\cmd.exe /c "set LANG=en_GB && start C:\git-sdk-64\git-bash.exe && exit" -Replace "en_GB" with your preferred locale. - - - +Replace "en_GB" with your preferred locale. \ No newline at end of file From 6c4028fe85e60badf30f0d4f93c717b7c9a51436 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Thu, 6 Oct 2016 14:06:21 +0200 Subject: [PATCH 209/591] Mention why support for XP/2K3 was dropped --- FAQ.md | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/FAQ.md b/FAQ.md index 402d71e95c4dd1..e73bb2d0d945ed 100644 --- a/FAQ.md +++ b/FAQ.md @@ -3,11 +3,10 @@ Git for Windows currently works with all recent, commercially released x86 32 bit and 64 bit versions of Windows, starting with Windows Vista. *** - NOTE: Git for Windows version [2.10.0](https://github.com/git-for-windows/git/releases/tag/v2.10.0.windows.1) was the last version supporting Windows XP and Server 2003. - *** +Windows XP and Windows Server 2003 are long past their end of life, hence support for these versions was dropped from Git for Windows 2.10.1 and later. This limitation is inherited by Git's use of MSYS2, which in turn inherited it from [Cygwin](https://cygwin.com/ml/cygwin/2015-08/msg00446.html). ## Should I upgrade to a newer Git for Windows version? From cc263f09c8dbc52c61dd837b17d8d9960dcbf084 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Thu, 20 Oct 2016 11:09:47 +0200 Subject: [PATCH 210/591] Add a section detailing how to permit user accounts other than administrators to create symbolic links --- Symbolic-Links.md | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/Symbolic-Links.md b/Symbolic-Links.md index 62ae823b641968..428728f6a47fb9 100644 --- a/Symbolic-Links.md +++ b/Symbolic-Links.md @@ -26,4 +26,8 @@ To create symbolic links (provided your account has permission to do so), use th ```cmd mklink /d this-link-points-to c:\that-directory mklink this-link-points-to c:\that-file -``` \ No newline at end of file +``` + +# Allowing non-administrators to create symbolic links + +Launch `gpedit.msc` (i.e. the group policy editor) and add the account(s) to `Computer configuration\Windows Setting\Security Settings\Local Policies\User Rights Assignment\Create symbolic links`. \ No newline at end of file From f18790bc6d7f7645b1f6175df99ee4fb374ab9a3 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Thu, 3 Nov 2016 10:17:00 +0100 Subject: [PATCH 211/591] Link to the prerequisites page (which Windows versions are supported?) --- FAQ.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/FAQ.md b/FAQ.md index e73bb2d0d945ed..acf64c7e738771 100644 --- a/FAQ.md +++ b/FAQ.md @@ -8,6 +8,8 @@ NOTE: Git for Windows version [2.10.0](https://github.com/git-for-windows/git/re Windows XP and Windows Server 2003 are long past their end of life, hence support for these versions was dropped from Git for Windows 2.10.1 and later. This limitation is inherited by Git's use of MSYS2, which in turn inherited it from [Cygwin](https://cygwin.com/ml/cygwin/2015-08/msg00446.html). +More information here: [Git for Windows' prerequisites](https://git-for-windows.github.io/requirements.html). + ## Should I upgrade to a newer Git for Windows version? In general, yes: it is a good idea to stay up-to-date. From 7910cc0eb0433bbdee07b2174c4574f47d84bbd0 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Sat, 5 Nov 2016 10:46:12 +0100 Subject: [PATCH 212/591] Describe what the heck MinGit is about --- MinGit.md | 28 ++++++++++++++++++++++++++++ 1 file changed, 28 insertions(+) create mode 100644 MinGit.md diff --git a/MinGit.md b/MinGit.md new file mode 100644 index 00000000000000..9a33a33234a8e9 --- /dev/null +++ b/MinGit.md @@ -0,0 +1,28 @@ +# MinGit is *Git for Windows Applications* + +## Rationale + +Git for Windows targets end users, and for a long time third-party applications that spawn `git.exe` in order to provide Git-specific functionality piggy-backed onto the end-user installation. + +However, for third-party applications it can be quite important to target certain minimum Git versions, e.g. when features such as `git reset --stdin` are needed that were introduced only recently. + +Bundling a complete portable Git for such cases may very well be overkill, as the applications that want to call Git usually do not require *all* of Git for Windows' functionality, *especially* not the interactive features including Git GUI and Git Bash. + +Enter MinGit. + +MinGit is an intentionally minimal, non-interactive distribution of Git for Windows, with third-party applications as its intended audience. + +## What is included in (or excluded from) MinGit? + +MinGit bundles `git.exe` and supporting cast, with an eye on trying to keep the size as small as possible without breaking non-interactive Git usage. To reduce the size, MinGit excludes localized messages, interactive commands, help documents, executables that are not called by `git.exe`, and the likes. + +As Tcl/Tk is only included in Git for Windows to support the Git GUI and `gitk` (both graphical, interactive components of Git), it is excluded from MinGit. + +Further, a conscious decision was made to exclude Perl. It is a *large* contributor to Git for Windows' size, and only very few, non-essential functions of Git require it: + +* `git add -i` (interactive, hence not needed) +* `git send-email` (highly unlikely that 3rd-party applications want to use *that*...) +* `git relink` (an old, old relic of the olden days before pack files, probably a good candidate for retirement to Git's own `contrib/` folder) +* CVS/Subversion adapters + +The only really contentious part of that list is the Subversion adapter, `git svn`. However, the space savings are substantial enough, and Subversion is no longer *that* prevalent enough, to ask third-party applications that *do* want to call `git svn` to bundle a full-fledged portable Git. \ No newline at end of file From 4930f8c06babd2bb832882d20d52e6755b03aea6 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?d=E2=9D=A4vid=20rix?= Date: Tue, 8 Nov 2016 16:13:22 +0200 Subject: [PATCH 213/591] add an MSI answer --- FAQ.md | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/FAQ.md b/FAQ.md index acf64c7e738771..81fd303be0d341 100644 --- a/FAQ.md +++ b/FAQ.md @@ -10,6 +10,17 @@ Windows XP and Windows Server 2003 are long past their end of life, hence suppor More information here: [Git for Windows' prerequisites](https://git-for-windows.github.io/requirements.html). +## Is there an MSI for installation via Group Policy? + +There is currently no MSI package; there is an exe installer and a portable package. You are welcome to contribute a Pull Request that packages a new installer. Have a look at https://github.com/robmen/gitsetup/issues/1 for an existing attempt. + +In the meantime you could try: + + * using the portable package + * deploying the exe installer with System Center Configuration Manager + * deploying the portable package via a script + * deploying the Chocolatey package via Puppet (or something similar) + ## Should I upgrade to a newer Git for Windows version? In general, yes: it is a good idea to stay up-to-date. From 0823c8cb99a6a843431010e82e98e6b343af5c01 Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Tue, 8 Nov 2016 20:20:12 +0000 Subject: [PATCH 214/591] suggest that folk/admins could test the current dev msi. --- FAQ.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/FAQ.md b/FAQ.md index 81fd303be0d341..7ef1e2226acec1 100644 --- a/FAQ.md +++ b/FAQ.md @@ -12,7 +12,7 @@ More information here: [Git for Windows' prerequisites](https://git-for-windows. ## Is there an MSI for installation via Group Policy? -There is currently no MSI package; there is an exe installer and a portable package. You are welcome to contribute a Pull Request that packages a new installer. Have a look at https://github.com/robmen/gitsetup/issues/1 for an existing attempt. +There is currently no MSI package; there is an exe installer and a portable package. You are welcome to test the current msi in development, or contribute a Pull Request that packages a new installer. Have a look at https://github.com/robmen/gitsetup/issues/1 for an existing attempt. In the meantime you could try: From e1b4a8afebbad69a2ecb5bd9eb9c7a301278b169 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Fri, 11 Nov 2016 16:55:29 +0100 Subject: [PATCH 215/591] Update the SDK link (pointed out by Ben Peart) --- Updating-your-SDK.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Updating-your-SDK.md b/Updating-your-SDK.md index 73b10cc1ad1fd9..c27c0ede688aef 100644 --- a/Updating-your-SDK.md +++ b/Updating-your-SDK.md @@ -1,4 +1,4 @@ -Extract from the [Git for Windows SDK release page](https://github.com/git-for-windows/build-extra/releases/tag/net-installer-1.0.0-rc-1). Note the Caution parts! +Extract from the [Git for Windows SDK release page](https://github.com/git-for-windows/build-extra/releases/latest). Note the Caution parts! # The SDK 'net installer' From ab3d553d00d22bc4fc8c9c3db89e4fa67d636ecd Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?d=E2=9D=A4vid=20rix?= Date: Tue, 15 Nov 2016 16:36:18 +0200 Subject: [PATCH 216/591] rewording with more direct sentences --- FAQ.md | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/FAQ.md b/FAQ.md index 7ef1e2226acec1..23b2101cd53574 100644 --- a/FAQ.md +++ b/FAQ.md @@ -12,7 +12,9 @@ More information here: [Git for Windows' prerequisites](https://git-for-windows. ## Is there an MSI for installation via Group Policy? -There is currently no MSI package; there is an exe installer and a portable package. You are welcome to test the current msi in development, or contribute a Pull Request that packages a new installer. Have a look at https://github.com/robmen/gitsetup/issues/1 for an existing attempt. +There is currently no MSI package; there is an exe installer and a portable package. You are welcome to contribute a Pull Request that packages a new installer. + +There is an existing Pull Request in development and looking for testers, please try out https://github.com/robmen/gitsetup/issues/1 and give feedback. In the meantime you could try: From cd6ba35d4268ea1d82a80f12afea03d2a0d19de9 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Fri, 25 Nov 2016 11:35:41 +0100 Subject: [PATCH 217/591] Remove unnecessary step --- Debugging-Git.md | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/Debugging-Git.md b/Debugging-Git.md index 09ff36e7a71efc..a8fc6e3dc5fe25 100644 --- a/Debugging-Git.md +++ b/Debugging-Git.md @@ -4,8 +4,7 @@ First of all, Git's `.exe` files should be rebuilt with debugging information, a 1. [install the Git for Windows SDK](https://git-for-windows.github.io/#download-sdk) 2. edit `/usr/src/git/Makefile` to remove the `-O2` from the `CFLAGS = -g -O2 -Wall` line, -3. edit `/usr/src/git/config.mak.uname` to remove the line `BASIC_LDFLAGS += -Wl,--dynamicbase`, and then -4. run `make` in `/usr/src/git/`. +3. run `make` in `/usr/src/git/`. After that, you can run Git's executables in GDB like so: From 0799f2f0ecb55c33dc4683665ee5e5a850bd01f0 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Fri, 25 Nov 2016 11:37:48 +0100 Subject: [PATCH 218/591] Clarify how to get the Git for Windows SDK shell back --- Technical-overview.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/Technical-overview.md b/Technical-overview.md index 7ae95b8a78e8d5..23e768f2317257 100644 --- a/Technical-overview.md +++ b/Technical-overview.md @@ -6,11 +6,11 @@ The process to build installer is made easy via the `Git for Windows SDK`. The s # Installing the SDK -Download the [SDK](https://git-for-windows.github.io/#download-sdk) and run it. You will end up with a console window running the `Git for Windows SDK` MSys shell, which you can use for the next steps. Git is already checked out and the latest version build and installed, so if you just want to build an installer from latest master, you are ready to go. +Download the [SDK](https://git-for-windows.github.io/#download-sdk) and run it. You will end up with a console window running the `Git for Windows SDK` shell, which you can use for the next steps. Git is already checked out and the latest version build and installed, so if you just want to build an installer from latest master, you are ready to go. -You can open the `Git for Windows SDK` MSys shell by double clicking `msys2_shell.bat` in the install folder (i.e. not the MinGW 32-bit nor the MinGW 64-bit one). +You can open the `Git for Windows SDK` shell by double clicking `git-bash.exe` in the install folder. -As the installer is made by putting together files from the Git SDK, it is advisable to update those files first. To update the packages, call `pacman -Syu` ([caveats apply](https://github.com/git-for-windows/git/wiki/Package-management#updating-msys2-runtime-pacman-and-bash)). +As the installer is made by putting together files from the Git for Windows SDK, it is advisable to update those files first. To update the packages, call `pacman -Syu` ([caveats apply](https://github.com/git-for-windows/git/wiki/Package-management#updating-msys2-runtime-pacman-and-bash)). # Hacking on git From b57a8917ef338826636370cb37c10831b30688dd Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Fri, 25 Nov 2016 12:20:33 +0100 Subject: [PATCH 219/591] Describe the straight-forward, if boring, debugging process when back traces are somehow messed up --- Debugging-Git.md | 49 ++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 49 insertions(+) diff --git a/Debugging-Git.md b/Debugging-Git.md index a8fc6e3dc5fe25..030ccbd1f25d91 100644 --- a/Debugging-Git.md +++ b/Debugging-Git.md @@ -23,6 +23,55 @@ b die_builtin before calling `run` in `gdb` to stop execution at the appropriate time. +## Debugging crashes (segmentation faults) + +When a command crashes (i.e. throws a segmentation fault), running it in `gdb` as described above will stop when the command crashes. Once that is the case, you can obtain a back trace with `bt`. Example: + +``` +(gdb) bt +#0 setup_git_directory_gently_1 (nongit_ok=0x0) at setup.c:846 +#1 0x000000000057dfd8 in setup_git_directory_gently (nongit_ok=0x0) + at setup.c:937 +#2 0x000000000057e211 in setup_git_directory () at setup.c:1014 +#3 0x0000000000487bfc in cmd_rev_parse (argc=2, argv=0x1951a88, prefix=0x0) + at builtin/rev-parse.c:589 +#4 0x000000000040296a in run_builtin (p=0x5fb8e8 , argc=2, + argv=0x1951a88) at git.c:373 +#5 0x0000000000402c8d in handle_builtin (argc=2, argv=0x1951a88) at git.c:579 +#6 0x0000000000402e2a in run_argv (argcp=0x108fe00, argv=0x108fdb8) + at git.c:637 +#7 0x0000000000402fb9 in cmd_main (argc=2, argv=0x1951a88) at git.c:709 +#8 0x000000000049f699 in mingw_main (argc=3, argv=0x1951a80) + at common-main.c:40 +#9 0x000000000049f64d in main (argc=3, argv=0x3230498) at common-main.c:25 +``` + +This back trace shows which functions were called by which other functions. The inner-most code location is `#0`, which was called from `#1`, which was called from `#2`, etc. In the example above, the `main()` function called the `mingw_main()` function which in turn called the `cmd_main()` function, and so on, until eventually the `setup_git_directory_gently()` function was called, which then called the `setup_git_directory_gently_1()` function, where the execution was stopped to let you, the user, inspect the current state in the debugger. + +You can inspect the source code at the current code location using the `l` command (or specify a line number or even a file and a line number like so: `l git.c:709`, or a function name, like so: `l run_builtin`). + +You can navigate between the different stack frames using `up` and `down` (which is confusingly the opposite direction as in the list above). + +You can inspect variables' values using `p `. This can be a struct, even. Example: + +``` +(gdb) p cwd +$1 = {alloc = 129, len = 30, buf = 0x3236cb8 "C:/git-sdk-64/usr/src/git"} +(gdb) p cwd.buf +$2 = 0x3236cb8 "C:/git-sdk-64/usr/src/git" +``` + +In some cases, the back trace is not helpful, though, most likely because the stack was somehow messed up. These issues are harder to debug, and require a lot of guess work and patience: + +1. set a breakpoint on the main function of the command you called, e.g. `cmd_rev_parse` for `git rev-parse ...`: `b cmd_rev_parse` +2. start the debugging session: `r` +3. once execution stops in the main function, try to determine a reasonable next breakpoint by looking at the source: `l` (subsequent `l` commands will list more, `l ` will list from a given line number) +4. then set another breakpoint and continue: `b ` and then `c` +5. If the crash occurs in between those breakpoints, try to figure out a break point between the last two, i.e. go back to step 3 above (with the difference that the debugging session has to be restarted with `r` instead of continued with `c`). +6. If there is actually no line between the two latest breakpoints, i.e. if the crash occurs in a function that was called from the line on which rests the second-latest breakpoint, restart with `r` and then *step into that function* using `s`. Then repeat as above. +7. If the crash does *not* occur between those two breakpoints, disable the first breakpoint (so that subsequent restarts of the debugging session will not stop unnecessarily): `dis ` (where `` is the breakpoint's number that was printed when you set it via `b `. +8. Then continue with step 3 above. + # Debugging with GDB in Emacs First, install `emacs` and run it: From fccdd30c40340355d962ce3149564105373635d1 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Thu, 1 Dec 2016 18:01:06 +0100 Subject: [PATCH 220/591] Start documenting how to work with Git's sources in Visual Studio --- Compiling-Git-with-Visual-Studio.md | 35 +++++++++++++++++++++++++++++ 1 file changed, 35 insertions(+) create mode 100644 Compiling-Git-with-Visual-Studio.md diff --git a/Compiling-Git-with-Visual-Studio.md b/Compiling-Git-with-Visual-Studio.md new file mode 100644 index 00000000000000..6b1e3cca05da85 --- /dev/null +++ b/Compiling-Git-with-Visual-Studio.md @@ -0,0 +1,35 @@ +Please note: this page describes how to compile Git's source code in Visual Studio 2010 or later. + +# Checking out `vs/master` + +Git's source code (and hence also Git for Windows' source code) is [usually built using GNU C and GNU Make in a Git for Windows SDK](https://github.com/git-for-windows/git/wiki/Building-Git). + +However, as of Git for Windows v2.11.0, a much more convenient way is available: by cloning https://github.com/git-for-windows/git and checking out the `vs/master` branch, you will automatically have project definitions ready to go with Visual Studio. + +Simply open the `git.sln` file and build the solution. + +# Running the tests + +When building Git in Visual Studio, you do not actually need a full-blown Git for Windows SDK. Simply install Git for Windows, make sure that the entire solution was built, open a Git Bash and run the tests in the `t/` subdirectory. + +## Running an individual test + +To test, say, the interactive rebase functionality, simply run the appropriate test (the file names are pretty self-explanatory): + +```sh +sh t3404-rebase-interactive.sh +``` + +If you need much more verbose output, e.g. when a test is failing, use the `-i -v -x` options: + +```bash +bash t3404-rebase-interactive.sh -i -v -x +``` + +## Running the entire test suite + +You can use the `prove` tool (which *mostly* works reliably, sometimes you will see that a test exited "dubiously" but running it again individually would not show any signs of failure...): + +```sh +prove --timer --jobs 15 ./t[0-9]*.sh +``` \ No newline at end of file From f32f47dcd710027e3ff5551f4eef7dc314328dbd Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Thu, 8 Dec 2016 10:58:11 +0100 Subject: [PATCH 221/591] Mention explicitly how to open an MSys shell --- Package-management.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Package-management.md b/Package-management.md index a8aa313642359c..80f90013aae536 100644 --- a/Package-management.md +++ b/Package-management.md @@ -76,7 +76,7 @@ makepkg-mingw -s (The `-s` flag tells `makepkg` that it should install dependencies automatically as needed) -To build MSys packages, you need to start the `MSys` shell (which sets `MSYSTEM=MSYS` before running the Bash), clone the [`MSYS2-packages`](https://github.com/git-for-windows/MSYS2-packages) repository (recommended location: `/usr/src/MSYS2-packages`), `cd` to the appropriate subdirectory and call +To build MSys packages, you need to start the `MSys` shell (e.g. `C:\git-sdk-64\msys2_shell.cmd -msys`, which sets `MSYSTEM=MSYS` before running the Bash), clone the [`MSYS2-packages`](https://github.com/git-for-windows/MSYS2-packages) repository (recommended location: `/usr/src/MSYS2-packages`), `cd` to the appropriate subdirectory and call ```bas makepkg -s From d346d237d79aeba925a0069d099ad295514327ea Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Fri, 9 Dec 2016 21:08:14 +0000 Subject: [PATCH 222/591] Created Zip Archives - extracting the released archives (markdown) --- ...ives---extracting-the-released-archives.md | 21 +++++++++++++++++++ 1 file changed, 21 insertions(+) create mode 100644 Zip-Archives---extracting-the-released-archives.md diff --git a/Zip-Archives---extracting-the-released-archives.md b/Zip-Archives---extracting-the-released-archives.md new file mode 100644 index 00000000000000..72479bccb57e29 --- /dev/null +++ b/Zip-Archives---extracting-the-released-archives.md @@ -0,0 +1,21 @@ +The self-extracting 7z archives that are currently released (e.g. for the portable version) can easily be installed in a headless manner using the extraction options. + +The self-extracting 7z archives are far more compact than regular .zip archives as the compaction is done across the whole content, rather than file by file, which would make .zip files inconveniently large. + +For a quiet extraction of the archive from the command line: + +``` +> .\PortableGit-2.11.0-64-bit.7z.exe -y -gm2 -InstallPath="C:\\use\\double\\backslashes" +``` + +We use the old .sfx component that used to be hosted on http://7zsfx.info. This provides more options for a fully quiet extraction - as shown, in this case: + +* `-y` hide some prompts +* `-gm2` hides the extraction dialog completely (silent mode) +* `-InstallPath` sets the target path (you need double backslashes) + +You can still see the switches in the Internet Archive: https://web.archive.org/web/20160402074100/http://www.7zsfx.info/en/switches.html. (see also this helpful StackOverflow answer: http://stackoverflow.com/a/32105548). + + + +This page responds to the question in https://github.com/git-for-windows/git/issues/986 \ No newline at end of file From 7fb842dcc5c8bd5df0074ef18f2b5e9182661fae Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Fri, 9 Dec 2016 21:31:39 +0000 Subject: [PATCH 223/591] extracting 7z/zip files - iss #986 --- FAQ.md | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/FAQ.md b/FAQ.md index 23b2101cd53574..4005178970b1b9 100644 --- a/FAQ.md +++ b/FAQ.md @@ -43,7 +43,9 @@ For advanced users working with the *Git for Windows* SDK `pacman` is available For hashes see https://github.com/git-for-windows/git/releases -For (G4W) release notes see the [build-extra repo](https://github.com/git-for-windows/build-extra/blob/master/ReleaseNotes.md) or the top level of your installation (e.g. C:\Program Files\Git\ReleaseNotes.html). +For (G4W) release notes see the [build-extra repo](https://github.com/git-for-windows/build-extra/blob/master/ReleaseNotes.md), or the top level of your installation (e.g. C:\Program Files\Git\ReleaseNotes.html). + +For extracting 7z/zip archives see [page](https://github.com/git-for-windows/git/wiki/Zip-Archives---extracting-the-released-archives). ## Some native console programs don't work when run from Git Bash. How to fix it? From 85c1e2be94727f43b1daf16d0e5842928113a5cc Mon Sep 17 00:00:00 2001 From: Jonathan Hall Date: Wed, 18 Jan 2017 11:11:55 +0100 Subject: [PATCH 224/591] "quite a couple" WTF? "Quite two" doesn't make much sense. --- Symbolic-Links.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Symbolic-Links.md b/Symbolic-Links.md index 428728f6a47fb9..1b3a6e66fc88c8 100644 --- a/Symbolic-Links.md +++ b/Symbolic-Links.md @@ -2,7 +2,7 @@ Short version: there is no exact equivalent for POSIX symlinks on Windows, and t # Background -Starting with Windows Vista, there is support for symbolic links. These are not your grandfather's Unix symbolic links; They differ in quite a couple of ways: +Starting with Windows Vista, there is support for symbolic links. These are not your grandfather's Unix symbolic links; They differ in quite a few ways: - Symbolic links are only available on Windows Vista and later, most notably not on XP - You need the `SeCreateSymbolicLinkPrivilege` privilege, which is by default assigned only to Administrators but can be assigned to normal users using Local Security Policy (or via Active Directory). Home Editions of Windows Vista and Windows 7 do not have Local Security Policy, but the freely available Polsedit (http://www.southsoftware.com) can be used on these editions. Note that regardless of privilege assignment, members of the Administrators group will also require UAC elevation (see the full details in *Access Token Changes* just above https://msdn.microsoft.com/en-us/library/bb530410.aspx#vistauac_topic4) From a52df78be079803ff61ec1e9aa189bf31ff1a570 Mon Sep 17 00:00:00 2001 From: NewBie1993 Date: Sat, 11 Feb 2017 00:21:25 +0800 Subject: [PATCH 225/591] Updated Building msys2 runtime (markdown) --- Building-msys2-runtime.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Building-msys2-runtime.md b/Building-msys2-runtime.md index 66dc9362a9785b..cee58dbc3c5d2b 100644 --- a/Building-msys2-runtime.md +++ b/Building-msys2-runtime.md @@ -4,7 +4,7 @@ # Build `msys2-runtime` -1. Open the *Git for Windows SDK* *MSys* shell by double clicking `msys2_shell.bat` in the install folder. (i.e. not the *MinGW 32-bit* nor the *MinGW 64-bit* one). +1. Open the *Git for Windows SDK* *MSys* shell by double clicking `msys2_shell.cmd` in the install folder. (i.e. not the *MinGW 32-bit* nor the *MinGW 64-bit* one). 2. Install the MSYS2 Toolchain: `pacman -S msys2-devel base-devel`. From b47d0c2e57ad4317b88e29151ebcf50afae19e7a Mon Sep 17 00:00:00 2001 From: NewBie1993 Date: Sat, 11 Feb 2017 00:37:38 +0800 Subject: [PATCH 226/591] Updated Building msys2 runtime (markdown) --- Building-msys2-runtime.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Building-msys2-runtime.md b/Building-msys2-runtime.md index cee58dbc3c5d2b..882b92f75516a3 100644 --- a/Building-msys2-runtime.md +++ b/Building-msys2-runtime.md @@ -18,7 +18,7 @@ When there are bugs in the msys2-runtime (e.g. problems with the POSIX-to-Windows path mangling), you need to rebuild the `msys-2.0.dll`, possibly frequently. -To rebuild the `msys-2.0.dll` -- assuming that you have built it already as described above -- you first need to start an *MSys* shell by double-clicking the `msys2_shell.bat` script in your Git SDK's top-level directory. Then call `cd /usr/src/MSYs2-packagess/msys2-runtime/src/msys2-runtime/winsup/cygwin`. Now you can modify the source code to your heart's extent. It is actually a local clone of https://github.com/git-for-windows/msys2-runtime; you probably want to add your own fork as a remote. +To rebuild the `msys-2.0.dll` -- assuming that you have built it already as described above -- you first need to start an *MSys* shell by double-clicking the `msys2_shell.cmd` script in your Git SDK's top-level directory. Then call `cd /usr/src/MSYs2-packagess/msys2-runtime/src/msys2-runtime/winsup/cygwin`. Now you can modify the source code to your heart's extent. It is actually a local clone of https://github.com/git-for-windows/msys2-runtime; you probably want to add your own fork as a remote. To actually build the `msys-2.0.dll`, switch to `src/build--pc-msys/-pc-msys/winsup/cygwin` and type `make`. This will generate an `msys0.dll` file in that directory. This is the new `msys-2.0.dll`, but you cannot simply copy it into `/usr/bin/` because it is in use by the current `mintty` as well as by the current Bash. To update, you need to close all programs using the msys2-runtime (including all of the terminal windows), then copy the `msys0.dll` file, replacing the existing `/usr/bin/msys-2.0.dll`, either using Explorer, `cmd.exe` or a separate Git SDK (for example, when debugging the 64-bit msys2-runtime, a 32-bit Git SDK comes in real handy). You will **want** to make a backup copy of the old `msys-2.0.dll`... From 398bf76cb9ceb7f6ac9ac507f4b6e96731064973 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Sat, 11 Feb 2017 20:35:05 +0100 Subject: [PATCH 227/591] First attempt to jot down this invaluable information from memory. --- Performance-profiling-with-Visual-Studio.md | 15 +++++++++++++++ 1 file changed, 15 insertions(+) create mode 100644 Performance-profiling-with-Visual-Studio.md diff --git a/Performance-profiling-with-Visual-Studio.md b/Performance-profiling-with-Visual-Studio.md new file mode 100644 index 00000000000000..2e705504616afe --- /dev/null +++ b/Performance-profiling-with-Visual-Studio.md @@ -0,0 +1,15 @@ +A very powerful method to identify performance bottlenecks is *performance profiling*. Visual Studio (including the free-of-cost Community edition) offers convenient tools for that via the *Debug>Start Performance Profiler* menu entry. + +*This space intentionally left blank for volunteers to fill in walkthroughs with screenshots, and links for further reading* + += Analyze the performance of a Git command specified as a command-line = + +1. Open the "git.exe" file via *File>Open* +2. Specify the arguments and the working directory via *Debug>Debug properties* +3. *Debug>Start Performance Profiler* + +== Analyze executables compiled by GCC == + +Visual Studio obtains the debug information used in the output from ".pdb" files, but GCC does not generate debug information in that format. + +However, the debug information can be extracted from the ".exe" files and be written out as ".pdb" file via the ["cv2pdb" utility](https://github.com/rainers/cv2pdb). \ No newline at end of file From 3a7674dcd47db3a282777b56eb2119eb4b8d7c8d Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Mon, 13 Feb 2017 13:40:15 +0100 Subject: [PATCH 228/591] Adjust the menu entry labels (which I got wrong from memory), and fix the section headers' markup --- Performance-profiling-with-Visual-Studio.md | 14 +++++++++----- 1 file changed, 9 insertions(+), 5 deletions(-) diff --git a/Performance-profiling-with-Visual-Studio.md b/Performance-profiling-with-Visual-Studio.md index 2e705504616afe..50a05819d6659c 100644 --- a/Performance-profiling-with-Visual-Studio.md +++ b/Performance-profiling-with-Visual-Studio.md @@ -1,14 +1,18 @@ -A very powerful method to identify performance bottlenecks is *performance profiling*. Visual Studio (including the free-of-cost Community edition) offers convenient tools for that via the *Debug>Start Performance Profiler* menu entry. +A very powerful method to identify performance bottlenecks is *performance profiling*. Visual Studio (including the free-of-cost Community edition) offers convenient tools for that via the *Debug>Performance Profiler...* menu entry. + + *This space intentionally left blank for volunteers to fill in walkthroughs with screenshots, and links for further reading* -= Analyze the performance of a Git command specified as a command-line = + + +# Analyze the performance of a Git command specified as a command-line 1. Open the "git.exe" file via *File>Open* -2. Specify the arguments and the working directory via *Debug>Debug properties* -3. *Debug>Start Performance Profiler* +2. Specify the arguments and the working directory via *Debug>git Properties* +3. *Debug>Performance Profiler...* -== Analyze executables compiled by GCC == +## Analyze executables compiled by GCC Visual Studio obtains the debug information used in the output from ".pdb" files, but GCC does not generate debug information in that format. From 4dd1ba2c650721cb5cea1918b0cea0608aac34f0 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Mon, 13 Feb 2017 13:46:14 +0100 Subject: [PATCH 229/591] Mention gprof and VS' performance profiler --- Diagnosing-performance-issues.md | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/Diagnosing-performance-issues.md b/Diagnosing-performance-issues.md index bf953df927124d..3f8681a54f9761 100644 --- a/Diagnosing-performance-issues.md +++ b/Diagnosing-performance-issues.md @@ -1,5 +1,13 @@ Under certain circumstances, Git can become very slow on Windows. Here are a couple of hints to figure out why. +# Identify specific Git commands' performance issues + +If the problem lies with a specific Git command, the most straight-forward way to investigate is to use profiling tools. + +The canonical profiling tool in GCC's tool set is [`gprof`](https://sourceware.org/binutils/docs/gprof/). However, the MINGW version of the GCC tools offered by MSYS2 has been known to produce empty output on occasion. + +An more convenient alternative is to use [Visual Studio's Performance Profiler](https://github.com/git-for-windows/git/wiki/Performance-profiling-with-Visual-Studio) (which is available in the free-of-cost Community version) which offers a powerful graphical user interface. + # Trace executions in the Bash startup When starting Git Bash is already slow, edit the file `/etc/profile` and insert a `set -x` somewhere at the top. This command will tell Bash to echo the commands it is executing so that you can find out which commands are slow and investigate more closely in that direction. From 1e0c1f1b480900adf3e7d66788f3aacaf4bd29f0 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Wed, 1 Mar 2017 10:51:41 +0100 Subject: [PATCH 230/591] Adjust for more modern Git versions: we can pass `-x` as a script option (tracing only the test cases' commands, excluding the boilerplate from the test suite) --- Running-Git's-regression-tests.md | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/Running-Git's-regression-tests.md b/Running-Git's-regression-tests.md index 55e9344ed54b92..b09c56b9bce65b 100644 --- a/Running-Git's-regression-tests.md +++ b/Running-Git's-regression-tests.md @@ -21,7 +21,7 @@ When some tests fail, it is best to run them individually. This can be done usin - `sh t0001-*.sh -i` will run *t0001* and stop at the first failing test (as opposed to the default, to continue running the rest of the tests in the *t0001* test suite) - `sh t0001-*.sh -v` will show the output of the programs called by the tests - `sh t0001-*.sh -d` will keep the temporary directory in which the test was run, `trash directory.t0001-init/` (this is useful when comparing the output of tests between Git versions when the tests fail for one Git version but succeed for another). -- `sh -x t0001-*.sh` will print out the command-line of the programs before they are executed +- `sh t0001-*.sh -x` will print out the command-line of the programs before they are executed These options can be combined, too. @@ -32,24 +32,24 @@ These options can be combined, too. Often there will be a ton of output and not all of that output is relevant to investigate test failures. In those cases, it makes sense to redirect the output to a file: ```bash -sh -x t0001-*.sh -i -v 2>&1 | tee log.out +sh t0001-*.sh -i -v -x 2>&1 | tee log.out ``` Alternatively, the output can be redirected to a pager: ```bash -sh -x t0001-*.sh -i -v 2>&1 | less +sh t0001-*.sh -i -v -x 2>&1 | less ``` To enable a quicker round-trip for running tests when running them repeatedly (typically changing the code a tad after each iteration), you can ask the `less` pager to fake key-presses just after starting. For example, the following command-line will always search for the first occurrence of the characters "ERROR:" in the output: ```bash -sh -x t0001-*.sh -i -v 2>&1 | less +/ERROR: +sh t0001-*.sh -i -v -x 2>&1 | less +/ERROR: ``` ### `set -x` -The statement `set -x` in a shell script will turn on the execution trace (see the explanation of the `sh -x ...` invocation above), and `set +x` will turn it off. This is not only useful for adding debug output to the regression tests; It is also useful in the parts of Git that are still implemented as shell scripts (such as `git submodule`). +The statement `set -x` in a shell script will turn on the execution trace (see the explanation of the `sh ... -x` invocation above), and `set +x` will turn it off. This is not only useful for adding debug output to the regression tests; It is also useful in the parts of Git that are still implemented as shell scripts (such as `git submodule`). For even more sophisticated debugging, the `set -x` statement can be triggered conditionally. The following example would turn on execution tracing only when the current commit name starts with *cafebabe*: From 13e4bc1def8753e5def10283746a6def4cb5ef98 Mon Sep 17 00:00:00 2001 From: David Macek Date: Wed, 12 Apr 2017 14:59:56 +0200 Subject: [PATCH 231/591] Reword the information about `Create symbolic links` privilege, split basics from tools and guides --- Symbolic-Links.md | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) diff --git a/Symbolic-Links.md b/Symbolic-Links.md index 1b3a6e66fc88c8..56d3c7f0d17c9c 100644 --- a/Symbolic-Links.md +++ b/Symbolic-Links.md @@ -5,9 +5,9 @@ Short version: there is no exact equivalent for POSIX symlinks on Windows, and t Starting with Windows Vista, there is support for symbolic links. These are not your grandfather's Unix symbolic links; They differ in quite a few ways: - Symbolic links are only available on Windows Vista and later, most notably not on XP -- You need the `SeCreateSymbolicLinkPrivilege` privilege, which is by default assigned only to Administrators but can be assigned to normal users using Local Security Policy (or via Active Directory). Home Editions of Windows Vista and Windows 7 do not have Local Security Policy, but the freely available Polsedit (http://www.southsoftware.com) can be used on these editions. Note that regardless of privilege assignment, members of the Administrators group will also require UAC elevation (see the full details in *Access Token Changes* just above https://msdn.microsoft.com/en-us/library/bb530410.aspx#vistauac_topic4) +- You need the `SeCreateSymbolicLinkPrivilege` privilege, which is by default assigned only to Administrators but can be assigned to other users or user groups (see below). Note that regardless of privilege assignment, members of the Administrators group will also require UAC elevation (see the full details in the *Access Token Changes* section in this [document on UAC](https://msdn.microsoft.com/en-us/library/bb530410.aspx)). - Symbolic links on remote filesystems are disabled by default (call `fsutil behavior query SymlinkEvaluation` to find out) -- Symbolic links will only work on NTFS, not on FAT +- Symbolic links will only work on NTFS, not on FAT nor exFAT - Windows' symbolic links are typed: they need to know whether they point to a directory or to a file (for this reason, Git will update the type when it finds that it is wrong) - Many programs do not understand symbolic links @@ -30,4 +30,10 @@ mklink this-link-points-to c:\that-file # Allowing non-administrators to create symbolic links -Launch `gpedit.msc` (i.e. the group policy editor) and add the account(s) to `Computer configuration\Windows Setting\Security Settings\Local Policies\User Rights Assignment\Create symbolic links`. \ No newline at end of file +The privilege of `Create symbolic links` can be assigned using local policy editors (or via policies from Active Directory in case of domain accounts). Home Editions of Windows Vista and Windows 7 do not have these policy editors, but the freely available [Polsedit](http://www.southsoftware.com) can be used on these editions. + +- Local Group Policy Editor: Launch `gpedit.msc`, navigate to `Computer configuration - Windows Setting - Security Settings - Local Policies - User Rights Assignment` and add the account(s) to the list named `Create symbolic links`. + +- Local Security Policy: Launch `secpol.msc`, navigate to `Security Settings - Local Policies - User Rights Assignment` and add the account(s) to the list named `Create symbolic links`. + +- Polsedit: Launch `polseditx32.exe` or `polseditx64.exe` (depending on your Windows version), navigate to `Security Settings - User Rights Assignment` and add the account(s) to the list named `Create symbolic links`. From 1382e33701cdfb456741b13e060b47a5170dd5f3 Mon Sep 17 00:00:00 2001 From: David Macek Date: Wed, 12 Apr 2017 15:11:14 +0200 Subject: [PATCH 232/591] Mention Developer Mode in Windows 10 CU removes UAC restriction --- Symbolic-Links.md | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/Symbolic-Links.md b/Symbolic-Links.md index 56d3c7f0d17c9c..b192512088cd94 100644 --- a/Symbolic-Links.md +++ b/Symbolic-Links.md @@ -5,7 +5,7 @@ Short version: there is no exact equivalent for POSIX symlinks on Windows, and t Starting with Windows Vista, there is support for symbolic links. These are not your grandfather's Unix symbolic links; They differ in quite a few ways: - Symbolic links are only available on Windows Vista and later, most notably not on XP -- You need the `SeCreateSymbolicLinkPrivilege` privilege, which is by default assigned only to Administrators but can be assigned to other users or user groups (see below). Note that regardless of privilege assignment, members of the Administrators group will also require UAC elevation (see the full details in the *Access Token Changes* section in this [document on UAC](https://msdn.microsoft.com/en-us/library/bb530410.aspx)). +- You need the `SeCreateSymbolicLinkPrivilege` privilege, which is by default assigned only to Administrators and guarded by UAC, but can be assigned to other users or user groups (see below). - Symbolic links on remote filesystems are disabled by default (call `fsutil behavior query SymlinkEvaluation` to find out) - Symbolic links will only work on NTFS, not on FAT nor exFAT - Windows' symbolic links are typed: they need to know whether they point to a directory or to a file (for this reason, Git will update the type when it finds that it is wrong) @@ -30,10 +30,14 @@ mklink this-link-points-to c:\that-file # Allowing non-administrators to create symbolic links -The privilege of `Create symbolic links` can be assigned using local policy editors (or via policies from Active Directory in case of domain accounts). Home Editions of Windows Vista and Windows 7 do not have these policy editors, but the freely available [Polsedit](http://www.southsoftware.com) can be used on these editions. +The privilege of `Create symbolic links` can be assigned using local policy editors (or via policies from Active Directory in case of domain accounts). Home Editions of Windows do not have these policy editors, but the freely available [Polsedit](http://www.southsoftware.com) can be used on these editions. - Local Group Policy Editor: Launch `gpedit.msc`, navigate to `Computer configuration - Windows Setting - Security Settings - Local Policies - User Rights Assignment` and add the account(s) to the list named `Create symbolic links`. - Local Security Policy: Launch `secpol.msc`, navigate to `Security Settings - Local Policies - User Rights Assignment` and add the account(s) to the list named `Create symbolic links`. - Polsedit: Launch `polseditx32.exe` or `polseditx64.exe` (depending on your Windows version), navigate to `Security Settings - User Rights Assignment` and add the account(s) to the list named `Create symbolic links`. + +Note that regardless of privilege assignment, members of the Administrators group will also require UAC elevation (see the full details in the *Access Token Changes* section in this [document on UAC](https://msdn.microsoft.com/en-us/library/bb530410.aspx)). Since Windows 10 version 1704 (*Creators Update*), enabling Developer Mode will disable this restriction and allow creating symlinks without UAC elevation[1]. + +[1] https://blogs.windows.com/buildingapps/2016/12/02/symlinks-windows-10/ \ No newline at end of file From d41361dc71c00666ce239ee8a85cbaa781226fbd Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Sat, 22 Apr 2017 18:23:47 +0100 Subject: [PATCH 233/591] Updated Updating your SDK (markdown) --- Updating-your-SDK.md | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/Updating-your-SDK.md b/Updating-your-SDK.md index c27c0ede688aef..9490c3b68698c1 100644 --- a/Updating-your-SDK.md +++ b/Updating-your-SDK.md @@ -1,3 +1,11 @@ +# Get your own copy of the SDK + +You can initialize your own copy of the SDK via `git clone --depth=1 https://github.com/git-for-windows/git-sdk-64` (or `...-32` for 32-bit)... (select depth to taste). [#816](https://github.com/git-for-windows/git/issues/816) + + +**** + + Extract from the [Git for Windows SDK release page](https://github.com/git-for-windows/build-extra/releases/latest). Note the Caution parts! # The SDK 'net installer' From 4cc5d9ca194a0cbe6e979abc24a668fc95231b86 Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Sat, 22 Apr 2017 18:25:04 +0100 Subject: [PATCH 234/591] Updated FAQ (markdown) --- FAQ.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/FAQ.md b/FAQ.md index 4005178970b1b9..62034019343284 100644 --- a/FAQ.md +++ b/FAQ.md @@ -31,7 +31,7 @@ If you have a version older than 2.7.4, it is *highly* advisable to upgrade. The ## What is the relationship between *Git for Windows* and *msysGit*? -*Git for Windows* used to be developed using the development environment called "msysGit", but roughly coinciding with Git 2.1, msysGit was superseded by a new development environment: the [Git for Windows SDK](https://github.com/git-for-windows/build-extra/releases). +*Git for Windows* used to be developed using the development environment called "msysGit", but roughly coinciding with Git 2.1, msysGit was superseded by a new development environment: the [Git for Windows SDK](https://github.com/git-for-windows/build-extra/releases). See [here](https://github.com/git-for-windows/git/wiki/Updating-your-SDK) to get a copy. ## How do I update *Git for Windows* upon new releases? From 7381b55b9f9544006ea604cada6775f5921e9ae4 Mon Sep 17 00:00:00 2001 From: UnluckyNinja Date: Wed, 26 Apr 2017 00:13:59 +0800 Subject: [PATCH 235/591] Add a note that indicates this is a guide for 64-bit msys2 --- Install-inside-MSYS2-proper.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index 8ddbe9d8bff01e..b0497e54984112 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -1,3 +1,5 @@ +**This guide will install 64-bit version of git-for windows inside your msys2. The "git" commands only works on 64-bit msys2 shell.** + Git for Windows being based on `MSYS2`, it's possible to install the `git` package into an existing `MSYS2` installation. That means that if you are already using `MSYS2` on your computer, you can use Git for Windows without running the full installer or using the portable version. Note however that there is some caveats for going this way. Git for Windows created some patches for `msys2-runtime` that have not yet been sent upstream (this is planned, checkout out issue [#284](https://github.com/git-for-windows/git/issues/284) for current status). This means that you have to install Git for Windows customized `msys2-runtime` to have a fully working `git` inside `MSYS2`. From 5d533b37e55e89b31577ce3c240cb3955496ea2f Mon Sep 17 00:00:00 2001 From: CharlesB Date: Thu, 4 May 2017 17:31:43 +0200 Subject: [PATCH 236/591] Import and update old page from msys wiki that is still useful (https://github.com/msysgit/msysgit/wiki/Silent-or-Unattended-Installation) --- Silent-or-Unattended-Installation.md | 32 ++++++++++++++++++++++++++++ 1 file changed, 32 insertions(+) create mode 100644 Silent-or-Unattended-Installation.md diff --git a/Silent-or-Unattended-Installation.md b/Silent-or-Unattended-Installation.md new file mode 100644 index 00000000000000..a3f6c3734f909f --- /dev/null +++ b/Silent-or-Unattended-Installation.md @@ -0,0 +1,32 @@ +It is possible to silently install msysgit using the following flags when called from a dos prompt: +``` +/SILENT /COMPONENTS="icons,ext\reg\shellhere,assoc,assoc_sh" +``` + +An example of this is +``` +Git-2.12.2.2-64-bit.exe /SILENT /COMPONENTS="icons,ext\reg\shellhere,assoc,assoc_sh" +``` +You can find all of the possible flags to use by inspecting the install.iss file: + +https://github.com/git-for-windows/build-extra/blob/master/installer/install.iss + +You can also load install parameters from a file with `/LOADINF="filename"`, and you can record parameters to a file using `/SAVEINF="filename"`. + +An example of a parameter file is: + +``` +[Setup] +Lang=default +Dir=C:\Program Files (x86)\Git +Group=Git +NoIcons=0 +SetupType=default +Components= +Tasks= +PathOption=Cmd +SSHOption=OpenSSH +CRLFOption=CRLFAlways +``` + +More information on commandline parameters can be found at http://www.jrsoftware.org/ishelp/index.php?topic=setupcmdline \ No newline at end of file From 9b288d216ebaf0235dcdd1a3188dfaf073f1db5e Mon Sep 17 00:00:00 2001 From: CharlesB Date: Thu, 4 May 2017 17:32:19 +0200 Subject: [PATCH 237/591] Updated Silent or Unattended Installation (markdown) --- Silent-or-Unattended-Installation.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Silent-or-Unattended-Installation.md b/Silent-or-Unattended-Installation.md index a3f6c3734f909f..cef7264fbcf38e 100644 --- a/Silent-or-Unattended-Installation.md +++ b/Silent-or-Unattended-Installation.md @@ -18,7 +18,7 @@ An example of a parameter file is: ``` [Setup] Lang=default -Dir=C:\Program Files (x86)\Git +Dir=C:\Program Files\Git Group=Git NoIcons=0 SetupType=default From 9fa9fd1efb0e732722a34ebf1d6986e17e7eb5b5 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Thu, 4 May 2017 20:54:37 +0200 Subject: [PATCH 238/591] Clarify/fix the recently added comment. --- Install-inside-MSYS2-proper.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index b0497e54984112..2e4e5a1ee75e56 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -1,4 +1,4 @@ -**This guide will install 64-bit version of git-for windows inside your msys2. The "git" commands only works on 64-bit msys2 shell.** +**This guide assumes that you want the 64-bit version of Git for Windows. To install the 32-bit version, replace the `x86_64` infix by `i686` in every command included in this document.** Git for Windows being based on `MSYS2`, it's possible to install the `git` package into an existing `MSYS2` installation. That means that if you are already using `MSYS2` on your computer, you can use Git for Windows without running the full installer or using the portable version. From 7b7b2b23ec381722605c7125d3c4ab8fd762bfdc Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Thu, 4 May 2017 21:00:42 +0200 Subject: [PATCH 239/591] Adjust (there is no msysgit no more, nor did this document ever talk about anything else than Git for Windows; and the set of recommended options changed) --- Silent-or-Unattended-Installation.md | 11 +++++------ 1 file changed, 5 insertions(+), 6 deletions(-) diff --git a/Silent-or-Unattended-Installation.md b/Silent-or-Unattended-Installation.md index cef7264fbcf38e..3dde95798a0a32 100644 --- a/Silent-or-Unattended-Installation.md +++ b/Silent-or-Unattended-Installation.md @@ -1,15 +1,14 @@ -It is possible to silently install msysgit using the following flags when called from a dos prompt: +It is possible to install Git for Windows silently using the following flags when called from a command-line prompt: ``` -/SILENT /COMPONENTS="icons,ext\reg\shellhere,assoc,assoc_sh" +Git--.exe /VERYSILENT /NORESTART /NOCANCEL /SP- /CLOSEAPPLICATIONS /RESTARTAPPLICATIONS /COMPONENTS="icons,ext\reg\shellhere,assoc,assoc_sh" ``` An example of this is ``` -Git-2.12.2.2-64-bit.exe /SILENT /COMPONENTS="icons,ext\reg\shellhere,assoc,assoc_sh" +Git-2.12.2.2-64-bit.exe /VERYSILENT /NORESTART /NOCANCEL /SP- /CLOSEAPPLICATIONS /RESTARTAPPLICATIONS /COMPONENTS="icons,ext\reg\shellhere,assoc,assoc_sh" ``` -You can find all of the possible flags to use by inspecting the install.iss file: -https://github.com/git-for-windows/build-extra/blob/master/installer/install.iss +You can find all of the possible flags to use by calling the installer with the `/?` flag (for the options supported by InnoSetup out of the box), and by inspecting the [`install.iss` file](https://github.com/git-for-windows/build-extra/blob/master/installer/install.iss) (for custom options added only to Git for Windows' installer). You can also load install parameters from a file with `/LOADINF="filename"`, and you can record parameters to a file using `/SAVEINF="filename"`. @@ -29,4 +28,4 @@ SSHOption=OpenSSH CRLFOption=CRLFAlways ``` -More information on commandline parameters can be found at http://www.jrsoftware.org/ishelp/index.php?topic=setupcmdline \ No newline at end of file +More information on commandline parameters can be found in [InnoSetup's documentation](http://www.jrsoftware.org/ishelp/index.php?topic=setupcmdline). \ No newline at end of file From 0739907e501a475390111d2a920da0b76975a060 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?P=C3=A9=C5=A5a=20Tom=C3=A1nek?= Date: Wed, 10 May 2017 15:40:26 +0200 Subject: [PATCH 240/591] Added licenses section (from git-for-windows/git/README.md and git-for-windows/build-extra/ReleaseNotes.md) to clarify licensing of Git for Windows. Surrounded Win-Command with Code-Span. --- FAQ.md | 21 +++++++++++++++++++-- 1 file changed, 19 insertions(+), 2 deletions(-) diff --git a/FAQ.md b/FAQ.md index 62034019343284..e76ec7385521b3 100644 --- a/FAQ.md +++ b/FAQ.md @@ -78,5 +78,22 @@ Some DSA keys are not considered secure anymore by OpenSSH 7. Adding "PubkeyAcce Some developers want to start git-bash (of Git for Windows SDK) with a different language. To achieve this in windows following command could be placed inside the launcher: -C:\Windows\System32\cmd.exe /c "set LANG=en_GB && start C:\git-sdk-64\git-bash.exe && exit" -Replace "en_GB" with your preferred locale. \ No newline at end of file +`C:\Windows\System32\cmd.exe /c "set LANG=en_GB && start C:\git-sdk-64\git-bash.exe && exit"` +replace `en_GB` with your preferred locale. + +## Licenses + +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. + +Git for Windows also contains Embedded CAcert Root Certificates. For +more information please go to +https://www.cacert.org/policy/RootDistributionLicense.php. + +This package contains software from a number of other projects +including Bash, zlib, curl, msmtp, tcl/tk, perl, MSYS2 and a number +of libraries and utilities from the GNU project, licensed under the +GNU General Public License. Likewise, it contains Perl which is dual +licensed under the GNU General Public License and the Artistic License. \ No newline at end of file From 402a6bb320e14fb44b951747bdb86c30f0517782 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Thu, 11 May 2017 14:55:20 +0200 Subject: [PATCH 241/591] FAQ (licenses): remove mstmp We do not ship it anymore... Signed-off-by: Johannes Schindelin --- FAQ.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/FAQ.md b/FAQ.md index e76ec7385521b3..63c3854ea697ee 100644 --- a/FAQ.md +++ b/FAQ.md @@ -93,7 +93,7 @@ more information please go to https://www.cacert.org/policy/RootDistributionLicense.php. This package contains software from a number of other projects -including Bash, zlib, curl, msmtp, tcl/tk, perl, MSYS2 and a number +including Bash, zlib, curl, tcl/tk, perl, MSYS2 and a number of libraries and utilities from the GNU project, licensed under the GNU General Public License. Likewise, it contains Perl which is dual licensed under the GNU General Public License and the Artistic License. \ No newline at end of file From ab38a6f0328793eef925c51f7881aa514b456620 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Thu, 11 May 2017 14:56:25 +0200 Subject: [PATCH 242/591] FAQ (licenses): let Markdown renderer justify the paragraphs Signed-off-by: Johannes Schindelin --- FAQ.md | 19 +++++-------------- 1 file changed, 5 insertions(+), 14 deletions(-) diff --git a/FAQ.md b/FAQ.md index 63c3854ea697ee..602c86fc4bee2d 100644 --- a/FAQ.md +++ b/FAQ.md @@ -83,17 +83,8 @@ replace `en_GB` with your preferred locale. ## Licenses -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. - -Git for Windows also contains Embedded CAcert Root Certificates. For -more information please go to -https://www.cacert.org/policy/RootDistributionLicense.php. - -This package contains software from a number of other projects -including Bash, zlib, curl, tcl/tk, perl, MSYS2 and a number -of libraries and utilities from the GNU project, licensed under the -GNU General Public License. Likewise, it contains Perl which is dual -licensed under the GNU General Public License and the Artistic License. \ No newline at end of file +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. + +Git for Windows also contains Embedded CAcert Root Certificates. For more information please go to https://www.cacert.org/policy/RootDistributionLicense.php. + +This package contains software from a number of other projects including Bash, zlib, curl, tcl/tk, perl, MSYS2 and a number of libraries and utilities from the GNU project, licensed under the GNU General Public License. Likewise, it contains Perl which is dual licensed under the GNU General Public License and the Artistic License. \ No newline at end of file From 381142fe50ac5db01f55c2485a444a24772ba0eb Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Thu, 11 May 2017 14:58:10 +0200 Subject: [PATCH 243/591] FAQ (licenses): add original link It would make more sense to auto-update it, but that would require somebody to put in the effort... Signed-off-by: Johannes Schindelin --- FAQ.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/FAQ.md b/FAQ.md index 602c86fc4bee2d..06bbb14c7c99b0 100644 --- a/FAQ.md +++ b/FAQ.md @@ -83,6 +83,8 @@ replace `en_GB` with your preferred locale. ## Licenses +Reproduced from [Git for Windows' release notes](https://github.com/git-for-windows/build-extra/blob/master/ReleaseNotes.md#licenses): + 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. Git for Windows also contains Embedded CAcert Root Certificates. For more information please go to https://www.cacert.org/policy/RootDistributionLicense.php. From ce8009d28adf3c8a3336568ebf10e11bcb55897f Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Sun, 21 May 2017 19:04:15 +0100 Subject: [PATCH 244/591] Capture the learning point from issue 1000 --- FAQ.md | 3 +++ 1 file changed, 3 insertions(+) diff --git a/FAQ.md b/FAQ.md index 06bbb14c7c99b0..2fc83b7a236049 100644 --- a/FAQ.md +++ b/FAQ.md @@ -64,6 +64,9 @@ There are several methods for working around these problems: ## I get errors trying to check out files with long path names. Windows file paths are by default limited to 255 characters. Some repositories may have committed files which contain paths longer than the limit. By default, *Git for Windows* does not support long paths, and will print errors when trying to perform any operation on a long file name. Set the configuration property `core.longpaths` to true to allow certain Git operations to properly handle these files. See [this wiki page](https://github.com/git-for-windows/git/wiki/Git-cannot-create-a-file-or-directory-with-a-long-path) for more information. +## Excel file modifications not always noticed. +Excel (and some other apps) do not update the *modified time* of its files which is used by Git to quickly detect changes. Rather Excel used the *change time* field. Git will notice the modifications if a `git status` is performed. See [issue 1000](https://github.com/git-for-windows/git/issues/1000#issuecomment-301611003) if you need more background. + ## How do I access a repository hosted on a Microsoft Team Foundation Server inside a Windows domain? The Microsoft Team Foundation Server is capable of hosting git repositories. If the server is a member of a windows domain, and your user account is in that domain, you can use domain authentication to identify yourself to the server, and can thus access git repositories without having to enter any credentials. For this to work, the server has to be configured to use domain authentication, _not_ NTLM authentication. The repository URL can be obtained from the TFS web interface, it may look like http://server.example.com:8080/tfs/TWA/TeamDev/_git/reponame. From 40cd136adec77050eeb5205ccd04a0c9c483956f Mon Sep 17 00:00:00 2001 From: Yue Lin Ho Date: Tue, 23 May 2017 10:03:17 +0800 Subject: [PATCH 245/591] Actually, can't compile it in VS2013 --- Compiling-Git-with-Visual-Studio.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Compiling-Git-with-Visual-Studio.md b/Compiling-Git-with-Visual-Studio.md index 6b1e3cca05da85..b1bc0f71be9300 100644 --- a/Compiling-Git-with-Visual-Studio.md +++ b/Compiling-Git-with-Visual-Studio.md @@ -1,4 +1,4 @@ -Please note: this page describes how to compile Git's source code in Visual Studio 2010 or later. +Please note: this page describes how to compile Git's source code in Visual Studio 2015 or later. # Checking out `vs/master` From e9c098f30652a0582a726454121b130a6db2c937 Mon Sep 17 00:00:00 2001 From: Charlie Orford Date: Fri, 2 Jun 2017 02:06:21 +0100 Subject: [PATCH 246/591] Updated Symbolic Links (markdown) --- Symbolic-Links.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Symbolic-Links.md b/Symbolic-Links.md index b192512088cd94..51754c13e9e2e5 100644 --- a/Symbolic-Links.md +++ b/Symbolic-Links.md @@ -38,6 +38,6 @@ The privilege of `Create symbolic links` can be assigned using local policy edit - Polsedit: Launch `polseditx32.exe` or `polseditx64.exe` (depending on your Windows version), navigate to `Security Settings - User Rights Assignment` and add the account(s) to the list named `Create symbolic links`. -Note that regardless of privilege assignment, members of the Administrators group will also require UAC elevation (see the full details in the *Access Token Changes* section in this [document on UAC](https://msdn.microsoft.com/en-us/library/bb530410.aspx)). Since Windows 10 version 1704 (*Creators Update*), enabling Developer Mode will disable this restriction and allow creating symlinks without UAC elevation[1]. +Note that regardless of privilege assignment, members of the Administrators group will also require UAC elevation (see the full details in the *Access Token Changes* section in this [document on UAC](https://msdn.microsoft.com/en-us/library/bb530410.aspx)). Since Windows 10 version 1704 (*Creators Update*), enabling Developer Mode will disable this restriction and allow creating symlinks without UAC elevation[1] (although Git for Windows still requires UAC elevation up to and including v2.13.0). [1] https://blogs.windows.com/buildingapps/2016/12/02/symlinks-windows-10/ \ No newline at end of file From 3098599840c5627bd3a16dbe65c64f7b8c14d0d3 Mon Sep 17 00:00:00 2001 From: Sagi Date: Fri, 2 Jun 2017 03:22:23 -0800 Subject: [PATCH 247/591] Updated Technical overview (markdown) From 00d9f48e423625de1e2205e362b6679c6bcb9310 Mon Sep 17 00:00:00 2001 From: Anton Derbenev Date: Tue, 27 Jun 2017 12:38:26 +0300 Subject: [PATCH 248/591] windows Creators Update actual version is 1703, not 1704 (YYMM) --- Symbolic-Links.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Symbolic-Links.md b/Symbolic-Links.md index 51754c13e9e2e5..323545a035c6a4 100644 --- a/Symbolic-Links.md +++ b/Symbolic-Links.md @@ -38,6 +38,6 @@ The privilege of `Create symbolic links` can be assigned using local policy edit - Polsedit: Launch `polseditx32.exe` or `polseditx64.exe` (depending on your Windows version), navigate to `Security Settings - User Rights Assignment` and add the account(s) to the list named `Create symbolic links`. -Note that regardless of privilege assignment, members of the Administrators group will also require UAC elevation (see the full details in the *Access Token Changes* section in this [document on UAC](https://msdn.microsoft.com/en-us/library/bb530410.aspx)). Since Windows 10 version 1704 (*Creators Update*), enabling Developer Mode will disable this restriction and allow creating symlinks without UAC elevation[1] (although Git for Windows still requires UAC elevation up to and including v2.13.0). +Note that regardless of privilege assignment, members of the Administrators group will also require UAC elevation (see the full details in the *Access Token Changes* section in this [document on UAC](https://msdn.microsoft.com/en-us/library/bb530410.aspx)). Since Windows 10 version 1703 (*Creators Update*), enabling Developer Mode will disable this restriction and allow creating symlinks without UAC elevation[1] (although Git for Windows still requires UAC elevation up to and including v2.13.0). [1] https://blogs.windows.com/buildingapps/2016/12/02/symlinks-windows-10/ \ No newline at end of file From a3751818ead084ab60c2cfea2a1dbe0fe33896a1 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Sun, 6 Aug 2017 00:29:04 +0200 Subject: [PATCH 249/591] Describe the experimental BusyBox flavor of MinGit --- MinGit.md | 25 ++++++++++++++++++++++++- 1 file changed, 24 insertions(+), 1 deletion(-) diff --git a/MinGit.md b/MinGit.md index 9a33a33234a8e9..27168f3aefac18 100644 --- a/MinGit.md +++ b/MinGit.md @@ -25,4 +25,27 @@ Further, a conscious decision was made to exclude Perl. It is a *large* contribu * `git relink` (an old, old relic of the olden days before pack files, probably a good candidate for retirement to Git's own `contrib/` folder) * CVS/Subversion adapters -The only really contentious part of that list is the Subversion adapter, `git svn`. However, the space savings are substantial enough, and Subversion is no longer *that* prevalent enough, to ask third-party applications that *do* want to call `git svn` to bundle a full-fledged portable Git. \ No newline at end of file +The only really contentious part of that list is the Subversion adapter, `git svn`. However, the space savings are substantial enough, and Subversion is no longer *that* prevalent enough, to ask third-party applications that *do* want to call `git svn` to bundle a full-fledged portable Git. + +# Experimental: BusyBox-based MinGit + +[BusyBox](https://busybox.net) is a project providing a single executable that implements small versions of a multitude of Unix utilities such as `sed`, `awk`, and even a Unix shell called `ash`. BusyBox tries to strike a balance between size and functionality, not aiming for complete POSIX compliance. [BusyBox-w32](https://github.com/rmyorston/busybox-w32) is a pure Win32 port of BusyBox, i.e. a single `.exe` file implementing those utilities without using the MSYS2 runtime. + +There are two advantages to avoiding the MSYS2 runtime: speed and robustness. In order to emulate POSIX semantics like `fork()`, the MSYS2 runtime needs to play certain tricks at startup, which slows down each and every invocation of MSYS2 programs, including Bash. Those tricks also entail a fixed DLL base address of `msys-2.0.dll` which in turn caused conflicts in some Git for Windows installations. Also, POSIX semantics for uids and gids need to be emulated for all kinds of different account types, sometimes leading to puzzling failures of the MSYS2 runtime to start. + +Naturally, using BusyBox-w32 instead of the MSYS2 Bash (and of the MSYS2 versions of the other Unix utilities required by Git's Unix shell scripts) would let us benefit from these advantages. + +Using BusyBox-w32 also offers a size advantage, being a single, tiny `.exe` file rather than a collection of `.dll` files and `.exe` files including more functionality than is strictly needed for Git's purposes. + +As it turns out, BusyBox' utilities provide all the functionality required to run Git's Unix shell scripts, and even almost all the functionality to run Git's test suite. + +Git for Windows v2.14.0 features experimental BusyBox-based MinGit versions. + +Note: the BusyBox-based MinGit versions are marked as experimental for at least the following reasons: +- BusyBox-based MinGit has not seen any serious, real-life testing, +- users might want to use more obscure options of the Unix utilities shipped with Git for Windows in their hooks or aliases, options that BusyBox may not (yet) support. + +Please also note that even if MinGit eventually switches to BusyBox completely, Git for Windows' installers will still ship with MSYS2's Bash for the time being: +- BusyBox-w32 has no idea (yet) about Git Bash's interactive terminal, and therefore does not support any interactive usage, +- Git Bash promises a full-featured *Bash*, not BusyBox' `ash`, +- with Git for Windows, it is even more likely that users may want to use functionality in their hooks and/or aliases which is not supported by BusyBox. \ No newline at end of file From fdab8f1cef91fe7bdab6856174e9528fb14766ca Mon Sep 17 00:00:00 2001 From: Loo Rong Jie Date: Tue, 8 Aug 2017 20:05:36 +0800 Subject: [PATCH 250/591] Destroyed _Footer (markdown) --- _Footer.md | 1 - 1 file changed, 1 deletion(-) delete mode 100644 _Footer.md diff --git a/_Footer.md b/_Footer.md deleted file mode 100644 index e206dc2d0d37d3..00000000000000 --- a/_Footer.md +++ /dev/null @@ -1 +0,0 @@ -This is the _Git for Windows_ wiki. See [how to participate](https://github.com/git-for-windows/git/wiki/How-to-participate). \ No newline at end of file From 66aba491468cb5aeea1fd2cca33f14f1f59f96bf Mon Sep 17 00:00:00 2001 From: Jeff Hostetler Date: Tue, 15 Aug 2017 11:29:14 -0400 Subject: [PATCH 251/591] Add "-y" option to emacs install command to ensure package databases are updated. --- Debugging-Git.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Debugging-Git.md b/Debugging-Git.md index 030ccbd1f25d91..69b821dc78345e 100644 --- a/Debugging-Git.md +++ b/Debugging-Git.md @@ -77,7 +77,7 @@ In some cases, the back trace is not helpful, though, most likely because the st First, install `emacs` and run it: ```sh -$ pacman -S mingw64/mingw-w64-x86_64-emacs +$ pacman -Sy mingw64/mingw-w64-x86_64-emacs $ emacs ``` From ec7189ed8e44bbeb1a53d30f7c821654adc5a735 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Tue, 15 Aug 2017 17:30:40 +0200 Subject: [PATCH 252/591] Revert "Destroyed _Footer (markdown)" This reverts commit fdab8f1cef91fe7bdab6856174e9528fb14766ca. --- _Footer.md | 1 + 1 file changed, 1 insertion(+) create mode 100644 _Footer.md diff --git a/_Footer.md b/_Footer.md new file mode 100644 index 00000000000000..e206dc2d0d37d3 --- /dev/null +++ b/_Footer.md @@ -0,0 +1 @@ +This is the _Git for Windows_ wiki. See [how to participate](https://github.com/git-for-windows/git/wiki/How-to-participate). \ No newline at end of file From be734de95aed16bac67be7e3fc6011efc6cafe77 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Tue, 15 Aug 2017 17:32:35 +0200 Subject: [PATCH 253/591] Mention that v2.14.1 fixed a critical security issue --- FAQ.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/FAQ.md b/FAQ.md index 2fc83b7a236049..a68e59dcaf139e 100644 --- a/FAQ.md +++ b/FAQ.md @@ -27,7 +27,7 @@ In the meantime you could try: In general, yes: it is a good idea to stay up-to-date. -If you have a version older than 2.7.4, it is *highly* advisable to upgrade. These versions fixed critical bugs, therefore sticking with older Git for Windows versions makes you vulnerable: 2.7.4, 2.7.0, 2.6.1, 2.5.2, 1.9.5-preview20150319, and 1.9.5-preview20141217. +If you have a version older than 2.14.1, it is *highly* advisable to upgrade. These versions fixed critical bugs, therefore sticking with older Git for Windows versions makes you vulnerable: 2.14.1, 2.7.4, 2.7.0, 2.6.1, 2.5.2, 1.9.5-preview20150319, and 1.9.5-preview20141217. ## What is the relationship between *Git for Windows* and *msysGit*? From c176e06f5e6fe93515a5444f826e2b4e642b0190 Mon Sep 17 00:00:00 2001 From: David Macek Date: Wed, 23 Aug 2017 12:36:37 +0200 Subject: [PATCH 254/591] Install inside MSYS2 proper: Add a temporary text noting that guide is outdated --- Install-inside-MSYS2-proper.md | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index 2e4e5a1ee75e56..90185b65cae831 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -1,3 +1,7 @@ +**This guide is outdated and needs fixing. See [#1277](https://github.com/git-for-windows/git/issues/1277) for *some* details.** + +--- + **This guide assumes that you want the 64-bit version of Git for Windows. To install the 32-bit version, replace the `x86_64` infix by `i686` in every command included in this document.** Git for Windows being based on `MSYS2`, it's possible to install the `git` package into an existing `MSYS2` installation. That means that if you are already using `MSYS2` on your computer, you can use Git for Windows without running the full installer or using the portable version. From d6dfeccbafae89d9d92d2d996cd22744e8e3791f Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Wed, 13 Sep 2017 15:07:42 +0200 Subject: [PATCH 255/591] Adjust lightly The document `Install inside MSYS2 proper` was *slightly* outdated: - `pacman` now handles core package updates differently - Git for Windows now signs the Pacman packages uploaded to Git for Windows' Pacman repository - Git for Windows currently requires a custom build of cURL (but it makes sense to keep up-to-date by consuming Git for Windows' cURL package anyway, because Git for Windows keeps an extra eye out for cURL updates) Signed-off-by: Johannes Schindelin --- Install-inside-MSYS2-proper.md | 25 ++++++++++++------------- 1 file changed, 12 insertions(+), 13 deletions(-) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index 90185b65cae831..588ba80d103f81 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -1,30 +1,29 @@ -**This guide is outdated and needs fixing. See [#1277](https://github.com/git-for-windows/git/issues/1277) for *some* details.** - ---- - **This guide assumes that you want the 64-bit version of Git for Windows. To install the 32-bit version, replace the `x86_64` infix by `i686` in every command included in this document.** Git for Windows being based on `MSYS2`, it's possible to install the `git` package into an existing `MSYS2` installation. That means that if you are already using `MSYS2` on your computer, you can use Git for Windows without running the full installer or using the portable version. -Note however that there is some caveats for going this way. Git for Windows created some patches for `msys2-runtime` that have not yet been sent upstream (this is planned, checkout out issue [#284](https://github.com/git-for-windows/git/issues/284) for current status). This means that you have to install Git for Windows customized `msys2-runtime` to have a fully working `git` inside `MSYS2`. +Note however that there are some caveats for going this way. Git for Windows created some patches for `msys2-runtime` that have not yet been sent upstream (this is planned, checkout out issue [#284](https://github.com/git-for-windows/git/issues/284) for current status). This means that you have to install Git for Windows customized `msys2-runtime` to have a fully working `git` inside `MSYS2`. Here the steps to take: 1. Open an `MSYS2` terminal. - 2. Edit `/etc/pacman.conf` and just before `[mingw32]` (line #71 on my machine), add the `git-for-windows` packages repository (Using `SigLevel = Optional TrustedOnly` because packages are not signed right now): + 2. Edit `/etc/pacman.conf` and just before `[mingw32]` (line #71 on my machine), add the `git-for-windows` packages repository: [git-for-windows] - SigLevel = Optional TrustedOnly Server = https://dl.bintray.com/git-for-windows/pacman/$arch 3. Then synchronize new repository - - pacman -Sy - 4. And finally install correct packages + pacman -Syu + + 4. This implicitly updates `msys2-runtime` and therefore will ask you to close the window (*not* just exit the pacman process). Don't panic, simply close all currently open shells and and program relying on `MSYS2` runtime. Once all close, start a new terminal again. + + 5. Then synchronize *again* (updating the non-core part of the packages): + + pacman -Syu - pacman -S git-for-windows/msys2-runtime git-for-windows/mingw-w64-x86_64-git git-for-windows/mingw-w64-x86_64-git-doc-html git-for-windows/mingw-w64-x86_64-git-doc-man + 6. And finally install the Git/cURL packages: - 5. Since you have updated `msys2-runtime`, you might get strange error messages right after finishing installation like an infinite stream of heap memory related messages. Don't panic, simply close all currently open shells and and program relying on `MSYS2` runtime. Once all close, start a new terminal again. + pacman -S mingw-w64-x86_64-git mingw-w64-x86_64-git-doc-html mingw-w64-x86_64-git-doc-man mingw-w64-x86_64-curl - 6. Finally, checkout that everything went well by doing `git --version` and it should output something like `git version 2.5.0.windows.1` \ No newline at end of file + 7. Finally, check that everything went well by doing `git --version` and it should output something like `git version 2.14.1.windows.1` (or newer). From 94f95eddabbe21513695be35df65d743f2dab7d2 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Mon, 2 Oct 2017 11:41:40 +0200 Subject: [PATCH 256/591] Mention the MINGW32/MINGW64 entries in `/etc/pacman.conf` (pointed out as missing by @elieux) --- Install-inside-MSYS2-proper.md | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index 588ba80d103f81..e4a615ba60e3eb 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -12,6 +12,16 @@ Here the steps to take: [git-for-windows] Server = https://dl.bintray.com/git-for-windows/pacman/$arch +and optionally also the MINGW-only repository for the *opposite* architecture (i.e. MINGW32 for 64-bit SDK, MINGW64 for 32-bit SDK): + + [git-for-windows-mingw32] + Server = https://dl.bintray.com/git-for-windows/pacman/i686 + +or + + [git-for-windows-mingw64] + Server = https://dl.bintray.com/git-for-windows/pacman/x86_64 + 3. Then synchronize new repository pacman -Syu From 9b58a5e82075f0d8d43720380afc2f5df9cbd9f7 Mon Sep 17 00:00:00 2001 From: How Who Date: Tue, 3 Oct 2017 14:09:42 +0200 Subject: [PATCH 257/591] Updated Building msys2 runtime (markdown) --- Building-msys2-runtime.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Building-msys2-runtime.md b/Building-msys2-runtime.md index 882b92f75516a3..8c90a1e0a298b8 100644 --- a/Building-msys2-runtime.md +++ b/Building-msys2-runtime.md @@ -4,7 +4,7 @@ # Build `msys2-runtime` -1. Open the *Git for Windows SDK* *MSys* shell by double clicking `msys2_shell.cmd` in the install folder. (i.e. not the *MinGW 32-bit* nor the *MinGW 64-bit* one). +1. Open the *Git for Windows SDK* *MSys* shell by launching `msys2_shell.cmd` with option `-msys` in the install folder. (i.e. not the *MinGW 32-bit* nor the *MinGW 64-bit* one). 2. Install the MSYS2 Toolchain: `pacman -S msys2-devel base-devel`. From eee3b870c1ebd87d172ee4de6c51a273c224998b Mon Sep 17 00:00:00 2001 From: David Macek Date: Tue, 3 Oct 2017 17:41:52 +0200 Subject: [PATCH 258/591] Add a step to install the correct signing key --- Install-inside-MSYS2-proper.md | 16 +++++++++++----- 1 file changed, 11 insertions(+), 5 deletions(-) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index e4a615ba60e3eb..bf114d635d821e 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -22,18 +22,24 @@ or [git-for-windows-mingw64] Server = https://dl.bintray.com/git-for-windows/pacman/x86_64 - 3. Then synchronize new repository + 3. Authorize signing key (this step may have to be repeated occasionally until https://github.com/msys2/msys2/issues/62 is fixed) + + curl -L https://raw.githubusercontent.com/git-for-windows/build-extra/master/git-for-windows-keyring/git-for-windows.gpg | + pacman-key --add - && + pacman-key --lsign-key 1A9F3986 + + 4. Then synchronize new repository pacman -Syu - 4. This implicitly updates `msys2-runtime` and therefore will ask you to close the window (*not* just exit the pacman process). Don't panic, simply close all currently open shells and and program relying on `MSYS2` runtime. Once all close, start a new terminal again. + 5. This implicitly updates `msys2-runtime` and therefore will ask you to close the window (*not* just exit the pacman process). Don't panic, simply close all currently open shells and and program relying on `MSYS2` runtime. Once all close, start a new terminal again. - 5. Then synchronize *again* (updating the non-core part of the packages): + 6. Then synchronize *again* (updating the non-core part of the packages): pacman -Syu - 6. And finally install the Git/cURL packages: + 7. And finally install the Git/cURL packages: pacman -S mingw-w64-x86_64-git mingw-w64-x86_64-git-doc-html mingw-w64-x86_64-git-doc-man mingw-w64-x86_64-curl - 7. Finally, check that everything went well by doing `git --version` and it should output something like `git version 2.14.1.windows.1` (or newer). + 8. Finally, check that everything went well by doing `git --version` and it should output something like `git version 2.14.1.windows.1` (or newer). From 7a8555ffcc1fed51ebcbc1ef3b6f9ef1ff3964bf Mon Sep 17 00:00:00 2001 From: Arkadiusz Piekarz Date: Mon, 9 Oct 2017 21:31:52 +0200 Subject: [PATCH 259/591] Change commands with pacman to easier to use pacboy and add git-extra package to install - to properly initialize git system config, like certificates location. --- Install-inside-MSYS2-proper.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index bf114d635d821e..39b44194b219eb 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -30,16 +30,16 @@ or 4. Then synchronize new repository - pacman -Syu + pacboy update 5. This implicitly updates `msys2-runtime` and therefore will ask you to close the window (*not* just exit the pacman process). Don't panic, simply close all currently open shells and and program relying on `MSYS2` runtime. Once all close, start a new terminal again. 6. Then synchronize *again* (updating the non-core part of the packages): - pacman -Syu + pacboy update 7. And finally install the Git/cURL packages: - pacman -S mingw-w64-x86_64-git mingw-w64-x86_64-git-doc-html mingw-w64-x86_64-git-doc-man mingw-w64-x86_64-curl + pacboy sync git:x git-doc-html:x git-doc-man:x git-extra: curl:x 8. Finally, check that everything went well by doing `git --version` and it should output something like `git version 2.14.1.windows.1` (or newer). From d5348eaf3d4585d37846e6eb86039689b393a53b Mon Sep 17 00:00:00 2001 From: Alberto Fanjul Date: Fri, 20 Oct 2017 06:41:17 +0200 Subject: [PATCH 260/591] explain how to run sdk and fix update of build-extra (checkout may do nothing) --- Making-an-installer.md | 31 +++++++++++++++++++++++++++---- 1 file changed, 27 insertions(+), 4 deletions(-) diff --git a/Making-an-installer.md b/Making-an-installer.md index 5e0081145e9bd3..5773a9ccd94473 100644 --- a/Making-an-installer.md +++ b/Making-an-installer.md @@ -1,11 +1,34 @@ -As the installer is made by putting together files from the Git SDK, it is advisable to update those files first. To update the packages, call `pacman -Syu` ([caveats apply](https://github.com/git-for-windows/git/wiki/Package-management#updating-msys2-runtime-pacman-and-bash)). If you want to test Git changes or make an installer from your own Git fork, you need to call `cd /usr/src/git && make install` (for documentation changes, `make install-html` and *afterwards* `prefix=/mingw64 make -C contrib/subtree install-html` - without the second `make` you get a error message about a missing `git-subtree.html` file). +As the installer is made by putting together files from the Git SDK, it is advisable to update those files first. To update the packages, call `pacman -Syu` ([caveats apply](https://github.com/git-for-windows/git/wiki/Package-management#updating-msys2-runtime-pacman-and-bash)). -To make an installer, install the [SDK](https://git-for-windows.github.io/#download-sdk), run it and then issue the following commands: +If you want to test Git changes or make an installer from your own Git fork, you need to call + +```bash +cd /usr/src/git +make install +``` +for documentation changes: + +```bash +make install-html +``` + +and *afterwards* + +```bash +prefix=/mingw64 make -C contrib/subtree install-html +``` + +>without this second `make` you get an error message about a missing `git-subtree.html` file). + +To make an installer, install the [SDK](https://git-for-windows.github.io/#download-sdk) and run it + +>Git for Windows SDK MinGW shell can be run by double-clicking either the Shortcut on the desktop Git SDK 32-bit.lnk or by double-clicking mingw32_shell.bat in the install folder. That is Git SDK 64-bit.lnk and mingw64_shell.bat for the 64bit SDK installer. + +then issue the following commands: ```bash cd /usr/src/build-extra -git fetch -git checkout master +git pull master ./installer/release.sh -test ``` From 210f24e075dc8b6283f2fd9806a82971ee07fa6f Mon Sep 17 00:00:00 2001 From: lastloverz Date: Thu, 26 Oct 2017 09:52:05 +0800 Subject: [PATCH 261/591] Updated How to participate (markdown) From 77c8760cbf2ec9f27cb6ac872bb8b8e95d682f2f Mon Sep 17 00:00:00 2001 From: mcnomad Date: Tue, 7 Nov 2017 02:55:11 +0100 Subject: [PATCH 262/591] Updated Symbolic Links (markdown) From 4043c08586c5794ac14c3d3e257389504fe4ba5a Mon Sep 17 00:00:00 2001 From: Viet Date: Thu, 7 Dec 2017 07:51:27 -0500 Subject: [PATCH 263/591] Created Screen buffer size scroll down issue (markdown) --- Screen-buffer-size-scroll-down-issue.md | 5 +++++ 1 file changed, 5 insertions(+) create mode 100644 Screen-buffer-size-scroll-down-issue.md diff --git a/Screen-buffer-size-scroll-down-issue.md b/Screen-buffer-size-scroll-down-issue.md new file mode 100644 index 00000000000000..1f8c2650b00ba3 --- /dev/null +++ b/Screen-buffer-size-scroll-down-issue.md @@ -0,0 +1,5 @@ +The cursor does not set the bottom of the terminal window (like in OSX or Linux), I can scroll down "infinitely" (the height of the screen buffer size) and use the mouse to click and drag any space below the cursor. This causes extra time looking for the cursor if I need to scroll up long rows of commands and their results, then need to scroll down. + +![gitbash window](https://i.stack.imgur.com/9Tdrs.png) + +In OSX or Linux, you cannot scroll down past the cursor. There's no good reasons to leave empty spaces under the cursor. I've tried editing Screen Buffer Size but it will just resize the whole window, then I cannot scroll up past the height of the screen buffer size. \ No newline at end of file From 92382c7dd6d488695f92ceaf570a01946cd6fef5 Mon Sep 17 00:00:00 2001 From: Viet Date: Thu, 7 Dec 2017 07:54:54 -0500 Subject: [PATCH 264/591] Updated Screen buffer size scroll down issue (markdown) --- Screen-buffer-size-scroll-down-issue.md | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/Screen-buffer-size-scroll-down-issue.md b/Screen-buffer-size-scroll-down-issue.md index 1f8c2650b00ba3..cfc962565ae52d 100644 --- a/Screen-buffer-size-scroll-down-issue.md +++ b/Screen-buffer-size-scroll-down-issue.md @@ -2,4 +2,7 @@ The cursor does not set the bottom of the terminal window (like in OSX or Linux) ![gitbash window](https://i.stack.imgur.com/9Tdrs.png) -In OSX or Linux, you cannot scroll down past the cursor. There's no good reasons to leave empty spaces under the cursor. I've tried editing Screen Buffer Size but it will just resize the whole window, then I cannot scroll up past the height of the screen buffer size. \ No newline at end of file +In OSX or Linux, you cannot scroll down past the cursor. There's no good reasons to leave empty spaces under the cursor. I've tried editing Screen Buffer Size but it will just resize the whole window, then I cannot scroll up past the height of the screen buffer size. + +I'm using Windows 10 Home. git version 2.13.2.windows.1 + From 40bb98186af8cf6b5d499a4ee80562f5c363d80f Mon Sep 17 00:00:00 2001 From: Viet Date: Thu, 7 Dec 2017 07:57:27 -0500 Subject: [PATCH 265/591] Destroyed Screen buffer size scroll down issue (markdown) --- Screen-buffer-size-scroll-down-issue.md | 8 -------- 1 file changed, 8 deletions(-) delete mode 100644 Screen-buffer-size-scroll-down-issue.md diff --git a/Screen-buffer-size-scroll-down-issue.md b/Screen-buffer-size-scroll-down-issue.md deleted file mode 100644 index cfc962565ae52d..00000000000000 --- a/Screen-buffer-size-scroll-down-issue.md +++ /dev/null @@ -1,8 +0,0 @@ -The cursor does not set the bottom of the terminal window (like in OSX or Linux), I can scroll down "infinitely" (the height of the screen buffer size) and use the mouse to click and drag any space below the cursor. This causes extra time looking for the cursor if I need to scroll up long rows of commands and their results, then need to scroll down. - -![gitbash window](https://i.stack.imgur.com/9Tdrs.png) - -In OSX or Linux, you cannot scroll down past the cursor. There's no good reasons to leave empty spaces under the cursor. I've tried editing Screen Buffer Size but it will just resize the whole window, then I cannot scroll up past the height of the screen buffer size. - -I'm using Windows 10 Home. git version 2.13.2.windows.1 - From 4f5edb5d56cb79b3ffc1052ed3555433dd594af4 Mon Sep 17 00:00:00 2001 From: guido <11861865+mcnomad81@users.noreply.github.com> Date: Sun, 4 Feb 2018 01:54:41 +0100 Subject: [PATCH 266/591] Updated Issue reporting guidelines (markdown) From 9786dc0b7f158459068b4e07286b932099e3da21 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Mon, 12 Feb 2018 11:08:44 +0100 Subject: [PATCH 267/591] Use the new homepage consistently We now use the domain gitforwindows.org, which is much easier to remember and quicker to type. Signed-off-by: Johannes Schindelin --- Building-Git.md | 8 ++++---- Building-msys2-runtime.md | 2 +- Debugging-Git.md | 2 +- FAQ.md | 4 ++-- Home.md | 2 +- How-to-participate.md | 6 +++--- Making-a-portable-Git.md | 4 ++-- Making-an-installer.md | 4 ++-- Rebasing-Git-for-Windows.md | 4 ++-- Technical-overview.md | 4 ++-- Vagrant.md | 8 ++++---- 11 files changed, 24 insertions(+), 24 deletions(-) diff --git a/Building-Git.md b/Building-Git.md index 7b15b687fa04ad..0c42b4c4377e0a 100644 --- a/Building-Git.md +++ b/Building-Git.md @@ -1,14 +1,14 @@ -We build Git for Windows using an [MSYS2](https://msys2.github.io/) based *Git for Windows SDK*. This SDK can be installed via the [SDK installer](https://git-for-windows.github.io/#download-sdk) +We build Git for Windows using an [MSYS2](https://msys2.github.io/) based *Git for Windows SDK*. This SDK can be installed via the [SDK installer](https://gitforwindows.org/#download-sdk) # Installing a build environment -1. Just run the [SDK installer](https://git-for-windows.github.io/#download-sdk). +1. Just run the [SDK installer](https://gitforwindows.org/#download-sdk). # Build Git -1. An initial `git clone` and `make` should have already occurred when running the [SDK installer](https://git-for-windows.github.io/#download-sdk). +1. An initial `git clone` and `make` should have already occurred when running the [SDK installer](https://gitforwindows.org/#download-sdk). -2. Open the *Git for Windows SDK* *MinGW* shell by double clicking either the Shortcut on the desktop `Git SDK 32-bit.lnk` or by double clicking `mingw32_shell.bat` in the install folder. That is `Git SDK 64-bit.lnk` and `mingw64_shell.bat` for the `64bit` [SDK installer](https://git-for-windows.github.io/#download-sdk). +2. Open the *Git for Windows SDK* *MinGW* shell by double clicking either the Shortcut on the desktop `Git SDK 32-bit.lnk` or by double clicking `mingw32_shell.bat` in the install folder. That is `Git SDK 64-bit.lnk` and `mingw64_shell.bat` for the `64bit` [SDK installer](https://gitforwindows.org/#download-sdk). 2. Change directory to the initial clone: `cd /usr/src/git`. diff --git a/Building-msys2-runtime.md b/Building-msys2-runtime.md index 8c90a1e0a298b8..a897341e69c9c1 100644 --- a/Building-msys2-runtime.md +++ b/Building-msys2-runtime.md @@ -1,6 +1,6 @@ # Installing a build environment -1. Just run the [SDK installer](https://git-for-windows.github.io/#download-sdk). +1. Just run the [SDK installer](https://gitforwindows.org/#download-sdk). # Build `msys2-runtime` diff --git a/Debugging-Git.md b/Debugging-Git.md index 69b821dc78345e..53d7c5a6828850 100644 --- a/Debugging-Git.md +++ b/Debugging-Git.md @@ -2,7 +2,7 @@ First of all, Git's `.exe` files should be rebuilt with debugging information, and without optimization (because `gdb` has serious troubles single-stepping code compiled using `-O2` for some reason). To this end: -1. [install the Git for Windows SDK](https://git-for-windows.github.io/#download-sdk) +1. [install the Git for Windows SDK](https://gitforwindows.org/#download-sdk) 2. edit `/usr/src/git/Makefile` to remove the `-O2` from the `CFLAGS = -g -O2 -Wall` line, 3. run `make` in `/usr/src/git/`. diff --git a/FAQ.md b/FAQ.md index a68e59dcaf139e..8ad3174e02a4d4 100644 --- a/FAQ.md +++ b/FAQ.md @@ -8,7 +8,7 @@ NOTE: Git for Windows version [2.10.0](https://github.com/git-for-windows/git/re Windows XP and Windows Server 2003 are long past their end of life, hence support for these versions was dropped from Git for Windows 2.10.1 and later. This limitation is inherited by Git's use of MSYS2, which in turn inherited it from [Cygwin](https://cygwin.com/ml/cygwin/2015-08/msg00446.html). -More information here: [Git for Windows' prerequisites](https://git-for-windows.github.io/requirements.html). +More information here: [Git for Windows' prerequisites](https://gitforwindows.org/requirements.html). ## Is there an MSI for installation via Group Policy? @@ -92,4 +92,4 @@ Git is an Open Source project covered by the GNU General Public License version Git for Windows also contains Embedded CAcert Root Certificates. For more information please go to https://www.cacert.org/policy/RootDistributionLicense.php. -This package contains software from a number of other projects including Bash, zlib, curl, tcl/tk, perl, MSYS2 and a number of libraries and utilities from the GNU project, licensed under the GNU General Public License. Likewise, it contains Perl which is dual licensed under the GNU General Public License and the Artistic License. \ No newline at end of file +This package contains software from a number of other projects including Bash, zlib, curl, tcl/tk, perl, MSYS2 and a number of libraries and utilities from the GNU project, licensed under the GNU General Public License. Likewise, it contains Perl which is dual licensed under the GNU General Public License and the Artistic License. diff --git a/Home.md b/Home.md index b5649f502b9548..10fff6fa423e5e 100644 --- a/Home.md +++ b/Home.md @@ -1,5 +1,5 @@ # Introduction -The _Git for Windows_ wiki. It looks more technical than [our home page](https://git-for-windows.github.io/) because it is the place where *you* [can contribute](https://github.com/git-for-windows/git/wiki/How-to-participate) to the documentation about _Git for Windows_. +The _Git for Windows_ wiki. It looks more technical than [our home page](https://gitforwindows.org/) because it is the place where *you* [can contribute](https://github.com/git-for-windows/git/wiki/How-to-participate) to the documentation about _Git for Windows_. ## About _Git for Windows_ is very different from _Git_ for almost everything else in one important respect: Windows does not provide the *POSIX* infrastructure Git expects. diff --git a/How-to-participate.md b/How-to-participate.md index 2642bf7ed1ee13..7b1d952369ae93 100644 --- a/How-to-participate.md +++ b/How-to-participate.md @@ -1,4 +1,4 @@ -There are several ways to participate in the Git for Windows project. First off, have a look at the [governance model](http://git-for-windows.github.io/governance-model.html) of the project. +There are several ways to participate in the Git for Windows project. First off, have a look at the [governance model](https://gitforwindows.org/governance-model.html) of the project. # Help users @@ -10,10 +10,10 @@ A lot of documentation wants to be written, still. A good place is [the Git for # Fix bugs or add features in the Git code itself -Download [the SDK](http://git-for-windows.github.io/#download-sdk) and build Git. Also have a look at [this page](https://github.com/git-for-windows/git/wiki/Building-Git) for tips and tricks revolving around building and debugging Git. +Download [the SDK](https://gitforwindows.org/#download-sdk) and build Git. Also have a look at [this page](https://github.com/git-for-windows/git/wiki/Building-Git) for tips and tricks revolving around building and debugging Git. Please also sign off your work, as [asked by the Git project](https://github.com/git/git/blob/v2.3.5/Documentation/SubmittingPatches#L234-L286) After that, submit a Pull Request. -Sometimes there are good suggestions how to improve the patches in a Pull Request. When that happens, just [rewrite and force-push the branch](https://robots.thoughtbot.com/git-interactive-rebase-squash-amend-rewriting-history). \ No newline at end of file +Sometimes there are good suggestions how to improve the patches in a Pull Request. When that happens, just [rewrite and force-push the branch](https://robots.thoughtbot.com/git-interactive-rebase-squash-amend-rewriting-history). diff --git a/Making-a-portable-Git.md b/Making-a-portable-Git.md index b896752d47317c..3021f7f90e165d 100644 --- a/Making-a-portable-Git.md +++ b/Making-a-portable-Git.md @@ -1,6 +1,6 @@ As the portable Git is made by putting together files from the Git SDK, it is advisable to update those files first. To update the packages, call `pacman -Syu` ([caveats apply](https://github.com/git-for-windows/git/wiki/Package-management#updating-msys2-runtime-pacman-and-bash)). If you want to test Git changes or make an portable Git from your own Git fork, you need to call `cd /usr/src/git && make install` (for documentation changes, `make install-html` and *afterwards* `prefix=/mingw64 make -C contrib/subtree install-html` - without the second `make` you get a error message about a missing `git-subtree.html` file). -To package the portable Git, install the [SDK](https://git-for-windows.github.io/#download-sdk), run it and then issue the following commands: +To package the portable Git, install the [SDK](https://gitforwindows.org/#download-sdk), run it and then issue the following commands: ```bash cd /usr/src/build-extra @@ -9,4 +9,4 @@ git checkout master ./portable/release.sh -test ``` -where `` is the Git version. \ No newline at end of file +where `` is the Git version. diff --git a/Making-an-installer.md b/Making-an-installer.md index 5773a9ccd94473..6e0f20b549ba41 100644 --- a/Making-an-installer.md +++ b/Making-an-installer.md @@ -20,7 +20,7 @@ prefix=/mingw64 make -C contrib/subtree install-html >without this second `make` you get an error message about a missing `git-subtree.html` file). -To make an installer, install the [SDK](https://git-for-windows.github.io/#download-sdk) and run it +To make an installer, install the [SDK](https://gitforwindows.org/#download-sdk) and run it >Git for Windows SDK MinGW shell can be run by double-clicking either the Shortcut on the desktop Git SDK 32-bit.lnk or by double-clicking mingw32_shell.bat in the install folder. That is Git SDK 64-bit.lnk and mingw64_shell.bat for the 64bit SDK installer. @@ -32,4 +32,4 @@ git pull master ./installer/release.sh -test ``` -where `` is the Git version (please note that the `` cannot contain dots after the numerical version: `2.7.2-hello-world` is okay while `2.7.2.hello.world` is not okay). \ No newline at end of file +where `` is the Git version (please note that the `` cannot contain dots after the numerical version: `2.7.2-hello-world` is okay while `2.7.2.hello.world` is not okay). diff --git a/Rebasing-Git-for-Windows.md b/Rebasing-Git-for-Windows.md index 877269465ffd7e..b8d4bd8afc3b94 100644 --- a/Rebasing-Git-for-Windows.md +++ b/Rebasing-Git-for-Windows.md @@ -5,7 +5,7 @@ To do a *rebase* of the *Git for Windows* source onto a new [upstream](https://g 2. The latest *rebase* was done onto a [upstream](https://github.com/git/git) release tagged as `v2.3.3` # Preconditions -1. A working [Git for Windows SDK](https://git-for-windows.github.io/#download-sdk). +1. A working [Git for Windows SDK](https://gitforwindows.org/#download-sdk). 2. A fetched build-extra repository. `cd /usr/src/build-extra` `git fetch` @@ -37,4 +37,4 @@ To do a *rebase* of the *Git for Windows* source onto a new [upstream](https://g >It's a bit hard to read, though, because it is a diff of a diff. >So meta. >When there is a line that starts with a `-` or a `+` but then continues with a space, that's good! - >It means that the context of our changes changed. \ No newline at end of file + >It means that the context of our changes changed. diff --git a/Technical-overview.md b/Technical-overview.md index 23e768f2317257..6323808df7117d 100644 --- a/Technical-overview.md +++ b/Technical-overview.md @@ -6,7 +6,7 @@ The process to build installer is made easy via the `Git for Windows SDK`. The s # Installing the SDK -Download the [SDK](https://git-for-windows.github.io/#download-sdk) and run it. You will end up with a console window running the `Git for Windows SDK` shell, which you can use for the next steps. Git is already checked out and the latest version build and installed, so if you just want to build an installer from latest master, you are ready to go. +Download the [SDK](https://gitforwindows.org/#download-sdk) and run it. You will end up with a console window running the `Git for Windows SDK` shell, which you can use for the next steps. Git is already checked out and the latest version build and installed, so if you just want to build an installer from latest master, you are ready to go. You can open the `Git for Windows SDK` shell by double clicking `git-bash.exe` in the install folder. @@ -58,4 +58,4 @@ See also: * [Debugging git](Debugging-Git) with gdb * Running Git's [regression tests](Running-Git's-regression-tests) * Msys/Mingw [package management](Package-management#technical-details) -* [Updating the SDK](https://github.com/git-for-windows/git/wiki/Updating-your-SDK) \ No newline at end of file +* [Updating the SDK](https://github.com/git-for-windows/git/wiki/Updating-your-SDK) diff --git a/Vagrant.md b/Vagrant.md index 1967e067938ab9..a6d920886ebd27 100644 --- a/Vagrant.md +++ b/Vagrant.md @@ -1,6 +1,6 @@ # Introduction -[Vagrant](https://www.vagrantup.com/) is a modern way to define the requirements of a project. In the case of [Git for Windows](http://git-for-windows.github.io/), it allows us to set up a minimal virtual Linux machine that makes it easy to run the same revision of Git on Windows as well as on Linux without much effort. +[Vagrant](https://www.vagrantup.com/) is a modern way to define the requirements of a project. In the case of [Git for Windows](https://gitforwindows.org/), it allows us to set up a minimal virtual Linux machine that makes it easy to run the same revision of Git on Windows as well as on Linux without much effort. **Note**: while Vagrant makes things easy, quite a bit of bandwidth is required for the setup (roughly a gigabyte will be downloaded in total). @@ -8,7 +8,7 @@ 1. Download and install [VirtualBox](https://www.virtualbox.org) 2. Download and install [Vagrant](https://www.vagrantup.com/) -3. Install the [Git SDK](http://git-for-windows.github.io/#download-sdk) +3. Install the [Git SDK](https://gitforwindows.org/#download-sdk) 4. Run `vagrant up` in the `/usr/src/git` directory 5. Run `vagrant ssh` @@ -18,7 +18,7 @@ To compile and install Git, you will have to run `make clean` first because *Git # Alternative to the Git SDK way -If you cannot download and install the Git SDK for some reason or other, you could also clone [the Git source code](https://github.com/git-for-windows/git) using [Git for Windows](https://git-for-windows.github.io/) instead, but make sure that Unix line endings are used: `git clone -c core.autocrlf=false https://github.com/git-for-windows/git vagrant-git`. If Git for Windows does not even work for you, you could also download the source code [as a `.zip`](https://github.com/git-for-windows/git/archive/master.zip) and unpack it. +If you cannot download and install the Git SDK for some reason or other, you could also clone [the Git source code](https://github.com/git-for-windows/git) using [Git for Windows](https://gitforwindows.org/) instead, but make sure that Unix line endings are used: `git clone -c core.autocrlf=false https://github.com/git-for-windows/git vagrant-git`. If Git for Windows does not even work for you, you could also download the source code [as a `.zip`](https://github.com/git-for-windows/git/archive/master.zip) and unpack it. After that, continue with the `vagrant up` step above. @@ -52,4 +52,4 @@ sudo mount -t tmpfs -o size=10G tmpfs $HOME/tmp cd $HOME/tmp ``` -You will want to clone projects into that `$HOME/tmp/` directory so that the I/O intensive operations benefit fully from using Vagrant. \ No newline at end of file +You will want to clone projects into that `$HOME/tmp/` directory so that the I/O intensive operations benefit fully from using Vagrant. From 4b2a814d90f8651e82c56f95e75c504fd13ca8c2 Mon Sep 17 00:00:00 2001 From: Ross Smith II Date: Sat, 24 Feb 2018 07:08:59 -0800 Subject: [PATCH 268/591] Mklink is a built-in command, see https://en.wikipedia.org/wiki/NTFS_symbolic_link#Tools --- Symbolic-Links.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Symbolic-Links.md b/Symbolic-Links.md index 323545a035c6a4..d7577ae96195f2 100644 --- a/Symbolic-Links.md +++ b/Symbolic-Links.md @@ -21,7 +21,7 @@ git clone -c core.symlinks=true By default, the `ln -s` command in *Git Bash* does *not* create symbolic links. Instead, it creates copies. -To create symbolic links (provided your account has permission to do so), use the `mklink.exe` tool, like so: +To create symbolic links (provided your account has permission to do so), use the built-in `mklink` command, like so: ```cmd mklink /d this-link-points-to c:\that-directory From c1372e3f651bd4c9f15e7069af74660c9cfdaa06 Mon Sep 17 00:00:00 2001 From: caner Date: Sun, 25 Feb 2018 04:16:14 +0300 Subject: [PATCH 269/591] Updated Issue reporting guidelines (markdown) From b42fa02bb0a0eabfc66e1fc6b8cb3bcc876c39cd Mon Sep 17 00:00:00 2001 From: Dale Wyttenbach Date: Wed, 7 Mar 2018 10:40:09 -0600 Subject: [PATCH 270/591] New page as suggested by Johannes Schindelin --- Using-sshd-to-host-a-git-server.md | 11 +++++++++++ 1 file changed, 11 insertions(+) create mode 100644 Using-sshd-to-host-a-git-server.md diff --git a/Using-sshd-to-host-a-git-server.md b/Using-sshd-to-host-a-git-server.md new file mode 100644 index 00000000000000..b543769146c107 --- /dev/null +++ b/Using-sshd-to-host-a-git-server.md @@ -0,0 +1,11 @@ +Everything you need to host a git server on Windows is included with Git for Windows. + +### Configure sshd +### Run sshd +A simple way to start sshd automatically when you log in is to put a .BAT script in: +%USERPROFILE%\AppData\Roaming\Microsoft\Windows\Start Menu\Programs\Startup +Mine contains: +`cd /d %GIT_HOME%` +`%GIT_HOME%\usr\bin\sshd.exe` +### Test sshd +### Connect with git \ No newline at end of file From 7a669190cc33c53ab6fc4ca736a3ddb52b3a07ea Mon Sep 17 00:00:00 2001 From: Dale Wyttenbach Date: Wed, 7 Mar 2018 10:41:01 -0600 Subject: [PATCH 271/591] Updated Using sshd to host a git server (markdown) --- Using-sshd-to-host-a-git-server.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/Using-sshd-to-host-a-git-server.md b/Using-sshd-to-host-a-git-server.md index b543769146c107..47f0766f233f69 100644 --- a/Using-sshd-to-host-a-git-server.md +++ b/Using-sshd-to-host-a-git-server.md @@ -4,7 +4,9 @@ Everything you need to host a git server on Windows is included with Git for Win ### Run sshd A simple way to start sshd automatically when you log in is to put a .BAT script in: %USERPROFILE%\AppData\Roaming\Microsoft\Windows\Start Menu\Programs\Startup + Mine contains: + `cd /d %GIT_HOME%` `%GIT_HOME%\usr\bin\sshd.exe` ### Test sshd From 367d1940fb59c7888dd71ff57a3e6515dca0d72f Mon Sep 17 00:00:00 2001 From: asuerocampero <35767157+asuerocampero@users.noreply.github.com> Date: Wed, 7 Mar 2018 16:52:16 +0000 Subject: [PATCH 272/591] Created carrera_espacial (markdown) --- carrera_espacial.md | 1 + 1 file changed, 1 insertion(+) create mode 100644 carrera_espacial.md diff --git a/carrera_espacial.md b/carrera_espacial.md new file mode 100644 index 00000000000000..793f0b40f3922e --- /dev/null +++ b/carrera_espacial.md @@ -0,0 +1 @@ + From 6e57596060c97077fc68952916b3f8d0b954b80d Mon Sep 17 00:00:00 2001 From: Dale Wyttenbach Date: Wed, 7 Mar 2018 11:20:40 -0600 Subject: [PATCH 273/591] Updated Using sshd to host a git server (markdown) --- Using-sshd-to-host-a-git-server.md | 22 +++++++++++++++++++++- 1 file changed, 21 insertions(+), 1 deletion(-) diff --git a/Using-sshd-to-host-a-git-server.md b/Using-sshd-to-host-a-git-server.md index 47f0766f233f69..6b174c859c6285 100644 --- a/Using-sshd-to-host-a-git-server.md +++ b/Using-sshd-to-host-a-git-server.md @@ -1,6 +1,11 @@ Everything you need to host a git server on Windows is included with Git for Windows. +In these instructions it is assumed that Git for Windows is installed at %GIT_HOME% ### Configure sshd +You need to create a key pair within %GIT_HOME%\etc\ssh for sshd to use as the server identity. +e.g., ssh_host_rsa_key and ssh_host_rsa_key.pub +TODO: How to create the key pair + ### Run sshd A simple way to start sshd automatically when you log in is to put a .BAT script in: %USERPROFILE%\AppData\Roaming\Microsoft\Windows\Start Menu\Programs\Startup @@ -10,4 +15,19 @@ Mine contains: `cd /d %GIT_HOME%` `%GIT_HOME%\usr\bin\sshd.exe` ### Test sshd -### Connect with git \ No newline at end of file +Your ultimate goal is probably to be able to ssh into the server where you are running sshd, without having to enter your password. (There are security considerations which probably require you to consult policies within your local organization) I suggest you setup your user account(s) with ssh public key authentication for this. + +### Adding projects +I create projects directly in %GIT_HOME% with: +`git init --bare yourproject.git +Then from a client you can clone that project and add content to it from there. + +Note: Creating them there is probably not ideal when it comes time to upgrading Git version on the server, so you may want to consider this before starting out. + +### Connect with git +From your client machine (which may or may not be the same machine as the server) +Checkout projects via git clone with an ssh-protocol URL: +`git clone ssh://your.server/yourproject.git +Or if your local username on the client is different than on the server: +`git clone ssh://you@your.server/yourproject.git +If you have chosen to use public key authentication, you should not have to enter a password. \ No newline at end of file From 2cc525dd7542b64708259d5b921a90b1cbaf5406 Mon Sep 17 00:00:00 2001 From: Dale Wyttenbach Date: Wed, 7 Mar 2018 11:22:46 -0600 Subject: [PATCH 274/591] format --- Using-sshd-to-host-a-git-server.md | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/Using-sshd-to-host-a-git-server.md b/Using-sshd-to-host-a-git-server.md index 6b174c859c6285..7fca22d42fa3d6 100644 --- a/Using-sshd-to-host-a-git-server.md +++ b/Using-sshd-to-host-a-git-server.md @@ -4,6 +4,7 @@ In these instructions it is assumed that Git for Windows is installed at %GIT_HO ### Configure sshd You need to create a key pair within %GIT_HOME%\etc\ssh for sshd to use as the server identity. e.g., ssh_host_rsa_key and ssh_host_rsa_key.pub + TODO: How to create the key pair ### Run sshd @@ -19,7 +20,9 @@ Your ultimate goal is probably to be able to ssh into the server where you are r ### Adding projects I create projects directly in %GIT_HOME% with: + `git init --bare yourproject.git + Then from a client you can clone that project and add content to it from there. Note: Creating them there is probably not ideal when it comes time to upgrading Git version on the server, so you may want to consider this before starting out. @@ -28,6 +31,8 @@ Note: Creating them there is probably not ideal when it comes time to upgrading From your client machine (which may or may not be the same machine as the server) Checkout projects via git clone with an ssh-protocol URL: `git clone ssh://your.server/yourproject.git + Or if your local username on the client is different than on the server: `git clone ssh://you@your.server/yourproject.git + If you have chosen to use public key authentication, you should not have to enter a password. \ No newline at end of file From 1430da59a2aa4e575ec6c688e5a674484ac13d02 Mon Sep 17 00:00:00 2001 From: Dale Wyttenbach Date: Wed, 7 Mar 2018 11:23:57 -0600 Subject: [PATCH 275/591] Updated Using sshd to host a git server (markdown) --- Using-sshd-to-host-a-git-server.md | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/Using-sshd-to-host-a-git-server.md b/Using-sshd-to-host-a-git-server.md index 7fca22d42fa3d6..9e555818f0d5e9 100644 --- a/Using-sshd-to-host-a-git-server.md +++ b/Using-sshd-to-host-a-git-server.md @@ -13,15 +13,16 @@ A simple way to start sshd automatically when you log in is to put a .BAT script Mine contains: -`cd /d %GIT_HOME%` -`%GIT_HOME%\usr\bin\sshd.exe` +`cd /d %GIT_HOME% +%GIT_HOME%\usr\bin\sshd.exe` + ### Test sshd Your ultimate goal is probably to be able to ssh into the server where you are running sshd, without having to enter your password. (There are security considerations which probably require you to consult policies within your local organization) I suggest you setup your user account(s) with ssh public key authentication for this. ### Adding projects I create projects directly in %GIT_HOME% with: -`git init --bare yourproject.git +`git init --bare yourproject.git` Then from a client you can clone that project and add content to it from there. @@ -30,9 +31,9 @@ Note: Creating them there is probably not ideal when it comes time to upgrading ### Connect with git From your client machine (which may or may not be the same machine as the server) Checkout projects via git clone with an ssh-protocol URL: -`git clone ssh://your.server/yourproject.git +`git clone ssh://your.server/yourproject.git` Or if your local username on the client is different than on the server: -`git clone ssh://you@your.server/yourproject.git +`git clone ssh://you@your.server/yourproject.git` If you have chosen to use public key authentication, you should not have to enter a password. \ No newline at end of file From 3a43df1ac3e8b93faf3c15ab0daf4565424233c7 Mon Sep 17 00:00:00 2001 From: Dale Wyttenbach Date: Wed, 7 Mar 2018 11:24:37 -0600 Subject: [PATCH 276/591] Updated Using sshd to host a git server (markdown) --- Using-sshd-to-host-a-git-server.md | 1 + 1 file changed, 1 insertion(+) diff --git a/Using-sshd-to-host-a-git-server.md b/Using-sshd-to-host-a-git-server.md index 9e555818f0d5e9..8a6647b94e648b 100644 --- a/Using-sshd-to-host-a-git-server.md +++ b/Using-sshd-to-host-a-git-server.md @@ -14,6 +14,7 @@ A simple way to start sshd automatically when you log in is to put a .BAT script Mine contains: `cd /d %GIT_HOME% + %GIT_HOME%\usr\bin\sshd.exe` ### Test sshd From d2183fe72e2911110c580bf6708ac8e432a739ab Mon Sep 17 00:00:00 2001 From: Dale Wyttenbach Date: Wed, 7 Mar 2018 11:25:31 -0600 Subject: [PATCH 277/591] Updated Using sshd to host a git server (markdown) --- Using-sshd-to-host-a-git-server.md | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/Using-sshd-to-host-a-git-server.md b/Using-sshd-to-host-a-git-server.md index 8a6647b94e648b..41c2c0b86433b7 100644 --- a/Using-sshd-to-host-a-git-server.md +++ b/Using-sshd-to-host-a-git-server.md @@ -13,9 +13,8 @@ A simple way to start sshd automatically when you log in is to put a .BAT script Mine contains: -`cd /d %GIT_HOME% - -%GIT_HOME%\usr\bin\sshd.exe` +> cd /d %GIT_HOME% +> %GIT_HOME%\usr\bin\sshd.exe ### Test sshd Your ultimate goal is probably to be able to ssh into the server where you are running sshd, without having to enter your password. (There are security considerations which probably require you to consult policies within your local organization) I suggest you setup your user account(s) with ssh public key authentication for this. From ef9247d14d74ced43ca883e5a6bae7fa0043d7ca Mon Sep 17 00:00:00 2001 From: Dale Wyttenbach Date: Wed, 7 Mar 2018 11:26:30 -0600 Subject: [PATCH 278/591] Updated Using sshd to host a git server (markdown) --- Using-sshd-to-host-a-git-server.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/Using-sshd-to-host-a-git-server.md b/Using-sshd-to-host-a-git-server.md index 41c2c0b86433b7..07669d48d485ff 100644 --- a/Using-sshd-to-host-a-git-server.md +++ b/Using-sshd-to-host-a-git-server.md @@ -13,8 +13,8 @@ A simple way to start sshd automatically when you log in is to put a .BAT script Mine contains: -> cd /d %GIT_HOME% -> %GIT_HOME%\usr\bin\sshd.exe + cd /d %GIT_HOME% + %GIT_HOME%\usr\bin\sshd.exe ### Test sshd Your ultimate goal is probably to be able to ssh into the server where you are running sshd, without having to enter your password. (There are security considerations which probably require you to consult policies within your local organization) I suggest you setup your user account(s) with ssh public key authentication for this. From debec6e26e2875dcaa4a28117de628be97d0a8d4 Mon Sep 17 00:00:00 2001 From: Dale Wyttenbach Date: Wed, 7 Mar 2018 11:27:48 -0600 Subject: [PATCH 279/591] Updated Using sshd to host a git server (markdown) --- Using-sshd-to-host-a-git-server.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Using-sshd-to-host-a-git-server.md b/Using-sshd-to-host-a-git-server.md index 07669d48d485ff..8f3f3a94074a66 100644 --- a/Using-sshd-to-host-a-git-server.md +++ b/Using-sshd-to-host-a-git-server.md @@ -20,7 +20,7 @@ Mine contains: Your ultimate goal is probably to be able to ssh into the server where you are running sshd, without having to enter your password. (There are security considerations which probably require you to consult policies within your local organization) I suggest you setup your user account(s) with ssh public key authentication for this. ### Adding projects -I create projects directly in %GIT_HOME% with: +I create projects directly on the server in %GIT_HOME% with: `git init --bare yourproject.git` From 3f41a4a3214d85c11c2474c84b0ce275c43e7efc Mon Sep 17 00:00:00 2001 From: Dale Wyttenbach Date: Wed, 7 Mar 2018 11:31:30 -0600 Subject: [PATCH 280/591] Updated Using sshd to host a git server (markdown) --- Using-sshd-to-host-a-git-server.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/Using-sshd-to-host-a-git-server.md b/Using-sshd-to-host-a-git-server.md index 8f3f3a94074a66..d4e2cccfb7e5dc 100644 --- a/Using-sshd-to-host-a-git-server.md +++ b/Using-sshd-to-host-a-git-server.md @@ -31,9 +31,11 @@ Note: Creating them there is probably not ideal when it comes time to upgrading ### Connect with git From your client machine (which may or may not be the same machine as the server) Checkout projects via git clone with an ssh-protocol URL: + `git clone ssh://your.server/yourproject.git` Or if your local username on the client is different than on the server: + `git clone ssh://you@your.server/yourproject.git` If you have chosen to use public key authentication, you should not have to enter a password. \ No newline at end of file From 13c769697cfc3405d6103d0be6f0cec66eab12cc Mon Sep 17 00:00:00 2001 From: Dale Wyttenbach Date: Wed, 7 Mar 2018 12:07:41 -0600 Subject: [PATCH 281/591] Updated Using sshd to host a git server (markdown) --- Using-sshd-to-host-a-git-server.md | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/Using-sshd-to-host-a-git-server.md b/Using-sshd-to-host-a-git-server.md index d4e2cccfb7e5dc..fcc0b73132f72d 100644 --- a/Using-sshd-to-host-a-git-server.md +++ b/Using-sshd-to-host-a-git-server.md @@ -5,7 +5,9 @@ In these instructions it is assumed that Git for Windows is installed at %GIT_HO You need to create a key pair within %GIT_HOME%\etc\ssh for sshd to use as the server identity. e.g., ssh_host_rsa_key and ssh_host_rsa_key.pub -TODO: How to create the key pair +Here is a good description of how to create the key pair: + +http://www.geekride.com/how-to-generate-ssh-host-keys/ ### Run sshd A simple way to start sshd automatically when you log in is to put a .BAT script in: From f611b62a01be2fdd4a24fdcf948fb33b94c3a88a Mon Sep 17 00:00:00 2001 From: Dale Wyttenbach Date: Wed, 7 Mar 2018 12:14:32 -0600 Subject: [PATCH 282/591] Updated Using sshd to host a git server (markdown) --- Using-sshd-to-host-a-git-server.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Using-sshd-to-host-a-git-server.md b/Using-sshd-to-host-a-git-server.md index fcc0b73132f72d..c9e883dcd3ff04 100644 --- a/Using-sshd-to-host-a-git-server.md +++ b/Using-sshd-to-host-a-git-server.md @@ -3,7 +3,7 @@ In these instructions it is assumed that Git for Windows is installed at %GIT_HO ### Configure sshd You need to create a key pair within %GIT_HOME%\etc\ssh for sshd to use as the server identity. -e.g., ssh_host_rsa_key and ssh_host_rsa_key.pub +e.g., ssh_host_rsa_key and ssh_host_rsa_key.pub files Here is a good description of how to create the key pair: From a48143de6314877e72b0f4fec2a698b9621fe9fa Mon Sep 17 00:00:00 2001 From: Dale Wyttenbach Date: Wed, 7 Mar 2018 12:43:45 -0600 Subject: [PATCH 283/591] Setting up public key authentication --- Using-sshd-to-host-a-git-server.md | 20 +++++++++++++++++++- 1 file changed, 19 insertions(+), 1 deletion(-) diff --git a/Using-sshd-to-host-a-git-server.md b/Using-sshd-to-host-a-git-server.md index c9e883dcd3ff04..855ee87df40676 100644 --- a/Using-sshd-to-host-a-git-server.md +++ b/Using-sshd-to-host-a-git-server.md @@ -1,5 +1,5 @@ Everything you need to host a git server on Windows is included with Git for Windows. -In these instructions it is assumed that Git for Windows is installed at %GIT_HOME% +In these instructions it is assumed that Git for Windows is installed at %GIT_HOME% and that you have %GIT_HOME%\cmd in your path on both client and server machines. ### Configure sshd You need to create a key pair within %GIT_HOME%\etc\ssh for sshd to use as the server identity. @@ -21,6 +21,24 @@ Mine contains: ### Test sshd Your ultimate goal is probably to be able to ssh into the server where you are running sshd, without having to enter your password. (There are security considerations which probably require you to consult policies within your local organization) I suggest you setup your user account(s) with ssh public key authentication for this. +Start by attempting to ssh from your client to the server. Assuming this is the first time, you will be prompted with: + The authenticity of host 'localhost (::1)' can't be established. + ECDSA key fingerprint is SHA256:lZPvG6eLvsX6dRxey0ShBlYjQubifOX6yuk3atg7jQ0. + Are you sure you want to continue connecting (yes/no)? +Type 'yes' and hit enter. At this moment %USERPROFILE%\.ssh directory will be created for you, if it didn't exist already. In that directory will be a known_hosts file identifying this server as one that you trust. You should be prompted for your password at this point: Enter it in, and you should now have a remote shell on the server (Congratulations if this is your first remote shell on Windows) + +Now exit out of that shell to return to your local machine. In either a bash window or a cmd.exe window, cd to the .ssh directory found in your home directory. Type ssh-keygen and you will be prompted like this: + Generating public/private rsa key pair. + Enter file in which to save the key (/Users/yourname/.ssh/id_rsa): + Enter passphrase (empty for no passphrase): + Enter same passphrase again: +Depending on how physically secure your client machine is and your local security policies, you may choose to use an empty passphrase. The passphrase is used to gain access to your local key store, so if you use an empty passphrase anyone who has access to your client machine can impersonate you. + +Two files will have been generated, id_rsa which contains your private key and id_rsa.pub which contains your public key. Protect your private key and never share it with anyone. Append the contents of the id_rsa.pub file generated on the client to your ~/.ssh/authorized_keys on the server (create it if it doesn't exist) + +If you configure multiple client machines for you can copy your .ssh directory from client to client, and thus you would only need one public key in ~/.ssh/authorized_keys on the server. Just make sure you protect the contents of .ssh directory on each client. + + ### Adding projects I create projects directly on the server in %GIT_HOME% with: From 53a07a68eae440bf6cb8189cbf1c94f0caed0ec5 Mon Sep 17 00:00:00 2001 From: Dale Wyttenbach Date: Wed, 7 Mar 2018 12:44:29 -0600 Subject: [PATCH 284/591] format --- Using-sshd-to-host-a-git-server.md | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/Using-sshd-to-host-a-git-server.md b/Using-sshd-to-host-a-git-server.md index 855ee87df40676..5c4547b2fc0ce6 100644 --- a/Using-sshd-to-host-a-git-server.md +++ b/Using-sshd-to-host-a-git-server.md @@ -22,16 +22,20 @@ Mine contains: Your ultimate goal is probably to be able to ssh into the server where you are running sshd, without having to enter your password. (There are security considerations which probably require you to consult policies within your local organization) I suggest you setup your user account(s) with ssh public key authentication for this. Start by attempting to ssh from your client to the server. Assuming this is the first time, you will be prompted with: + The authenticity of host 'localhost (::1)' can't be established. ECDSA key fingerprint is SHA256:lZPvG6eLvsX6dRxey0ShBlYjQubifOX6yuk3atg7jQ0. Are you sure you want to continue connecting (yes/no)? + Type 'yes' and hit enter. At this moment %USERPROFILE%\.ssh directory will be created for you, if it didn't exist already. In that directory will be a known_hosts file identifying this server as one that you trust. You should be prompted for your password at this point: Enter it in, and you should now have a remote shell on the server (Congratulations if this is your first remote shell on Windows) Now exit out of that shell to return to your local machine. In either a bash window or a cmd.exe window, cd to the .ssh directory found in your home directory. Type ssh-keygen and you will be prompted like this: + Generating public/private rsa key pair. Enter file in which to save the key (/Users/yourname/.ssh/id_rsa): Enter passphrase (empty for no passphrase): Enter same passphrase again: + Depending on how physically secure your client machine is and your local security policies, you may choose to use an empty passphrase. The passphrase is used to gain access to your local key store, so if you use an empty passphrase anyone who has access to your client machine can impersonate you. Two files will have been generated, id_rsa which contains your private key and id_rsa.pub which contains your public key. Protect your private key and never share it with anyone. Append the contents of the id_rsa.pub file generated on the client to your ~/.ssh/authorized_keys on the server (create it if it doesn't exist) From 05aef2cc679edacb5ec7d582d9770c91d4fedb43 Mon Sep 17 00:00:00 2001 From: Dale Wyttenbach Date: Wed, 7 Mar 2018 12:48:34 -0600 Subject: [PATCH 285/591] Info on --- Using-sshd-to-host-a-git-server.md | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/Using-sshd-to-host-a-git-server.md b/Using-sshd-to-host-a-git-server.md index 5c4547b2fc0ce6..c3c473d28b0604 100644 --- a/Using-sshd-to-host-a-git-server.md +++ b/Using-sshd-to-host-a-git-server.md @@ -40,8 +40,9 @@ Depending on how physically secure your client machine is and your local securit Two files will have been generated, id_rsa which contains your private key and id_rsa.pub which contains your public key. Protect your private key and never share it with anyone. Append the contents of the id_rsa.pub file generated on the client to your ~/.ssh/authorized_keys on the server (create it if it doesn't exist) -If you configure multiple client machines for you can copy your .ssh directory from client to client, and thus you would only need one public key in ~/.ssh/authorized_keys on the server. Just make sure you protect the contents of .ssh directory on each client. +At this time you should be able to ssh from the client to the server without entering a password (but if you chose a non-empty passphrase the client will prompt you for that). When non-empty passphrase are used, there is also the option of running ssh-agent to keep the passphrase in-memory for you, but I'll not cover that here. +If you configure multiple client machines for you can copy your .ssh directory from client to client, and thus you would only need one public key in ~/.ssh/authorized_keys on the server. Just make sure you protect the contents of .ssh directory on each client. ### Adding projects I create projects directly on the server in %GIT_HOME% with: From 441133b67445b6d268e54a562483ffee656f065d Mon Sep 17 00:00:00 2001 From: Dale Wyttenbach Date: Wed, 7 Mar 2018 12:50:35 -0600 Subject: [PATCH 286/591] Updated Using sshd to host a git server (markdown) --- Using-sshd-to-host-a-git-server.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Using-sshd-to-host-a-git-server.md b/Using-sshd-to-host-a-git-server.md index c3c473d28b0604..c1f1adbc02e3a2 100644 --- a/Using-sshd-to-host-a-git-server.md +++ b/Using-sshd-to-host-a-git-server.md @@ -40,7 +40,7 @@ Depending on how physically secure your client machine is and your local securit Two files will have been generated, id_rsa which contains your private key and id_rsa.pub which contains your public key. Protect your private key and never share it with anyone. Append the contents of the id_rsa.pub file generated on the client to your ~/.ssh/authorized_keys on the server (create it if it doesn't exist) -At this time you should be able to ssh from the client to the server without entering a password (but if you chose a non-empty passphrase the client will prompt you for that). When non-empty passphrase are used, there is also the option of running ssh-agent to keep the passphrase in-memory for you, but I'll not cover that here. +At this time you should be able to ssh from the client to the server without entering a password (but if you chose a non-empty passphrase the client will prompt you for that). When a non-empty passphrase is used, there is also the option of running ssh-agent to keep the passphrase in-memory for you, but I'll not cover that here. If you configure multiple client machines for you can copy your .ssh directory from client to client, and thus you would only need one public key in ~/.ssh/authorized_keys on the server. Just make sure you protect the contents of .ssh directory on each client. From 747370f9dff724e58d6b6511509013fa176f38f8 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Thu, 8 Mar 2018 00:22:44 +0100 Subject: [PATCH 287/591] Delete bogus page Signed-off-by: Johannes Schindelin --- carrera_espacial.md | 1 - 1 file changed, 1 deletion(-) delete mode 100644 carrera_espacial.md diff --git a/carrera_espacial.md b/carrera_espacial.md deleted file mode 100644 index 793f0b40f3922e..00000000000000 --- a/carrera_espacial.md +++ /dev/null @@ -1 +0,0 @@ - From 67991f88223e860b604edc0c2a8e02ec66d9cc0a Mon Sep 17 00:00:00 2001 From: Dale Wyttenbach Date: Wed, 7 Mar 2018 17:45:31 -0600 Subject: [PATCH 288/591] format --- Using-sshd-to-host-a-git-server.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Using-sshd-to-host-a-git-server.md b/Using-sshd-to-host-a-git-server.md index c1f1adbc02e3a2..3f9928645c7c59 100644 --- a/Using-sshd-to-host-a-git-server.md +++ b/Using-sshd-to-host-a-git-server.md @@ -27,7 +27,7 @@ Start by attempting to ssh from your client to the server. Assuming this is the ECDSA key fingerprint is SHA256:lZPvG6eLvsX6dRxey0ShBlYjQubifOX6yuk3atg7jQ0. Are you sure you want to continue connecting (yes/no)? -Type 'yes' and hit enter. At this moment %USERPROFILE%\.ssh directory will be created for you, if it didn't exist already. In that directory will be a known_hosts file identifying this server as one that you trust. You should be prompted for your password at this point: Enter it in, and you should now have a remote shell on the server (Congratulations if this is your first remote shell on Windows) +Type 'yes' and hit enter. At this moment %USERPROFILE%\\.ssh directory will be created for you, if it didn't exist already. In that directory will be a known_hosts file identifying this server as one that you trust. You should be prompted for your password at this point: Enter it in, and you should now have a remote shell on the server (Congratulations if this is your first remote shell on Windows) Now exit out of that shell to return to your local machine. In either a bash window or a cmd.exe window, cd to the .ssh directory found in your home directory. Type ssh-keygen and you will be prompted like this: From a0ca9dd1418950bf1de6e569b5284edb4d7cd3be Mon Sep 17 00:00:00 2001 From: mehrdadn Date: Mon, 12 Mar 2018 12:35:04 -0700 Subject: [PATCH 289/591] Updated Install inside MSYS2 proper (markdown) --- Install-inside-MSYS2-proper.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index 39b44194b219eb..fcf2ea0fa630cf 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -2,7 +2,7 @@ Git for Windows being based on `MSYS2`, it's possible to install the `git` package into an existing `MSYS2` installation. That means that if you are already using `MSYS2` on your computer, you can use Git for Windows without running the full installer or using the portable version. -Note however that there are some caveats for going this way. Git for Windows created some patches for `msys2-runtime` that have not yet been sent upstream (this is planned, checkout out issue [#284](https://github.com/git-for-windows/git/issues/284) for current status). This means that you have to install Git for Windows customized `msys2-runtime` to have a fully working `git` inside `MSYS2`. +Note however that there are some caveats for going this way. Git for Windows created some patches for `msys2-runtime` that have not been sent upstream. (This had been planned, but it was determined in issue [#284](/git-for-windows/git/issues/284) that it would probably not be happening.) This means that you have to install Git for Windows customized `msys2-runtime` to have a fully working `git` inside `MSYS2`. Here the steps to take: From 7fa605584167d6056101bcec9e6c1c82943d1a10 Mon Sep 17 00:00:00 2001 From: Niklas Holm Date: Tue, 20 Mar 2018 17:40:29 +0100 Subject: [PATCH 290/591] New repo urls (#1479) --- Install-inside-MSYS2-proper.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index fcf2ea0fa630cf..56208a9ca517a2 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -10,17 +10,17 @@ Here the steps to take: 2. Edit `/etc/pacman.conf` and just before `[mingw32]` (line #71 on my machine), add the `git-for-windows` packages repository: [git-for-windows] - Server = https://dl.bintray.com/git-for-windows/pacman/$arch + Server = https://wingit.blob.core.windows.net/$arch and optionally also the MINGW-only repository for the *opposite* architecture (i.e. MINGW32 for 64-bit SDK, MINGW64 for 32-bit SDK): [git-for-windows-mingw32] - Server = https://dl.bintray.com/git-for-windows/pacman/i686 + Server = https://wingit.blob.core.windows.net/i686 or [git-for-windows-mingw64] - Server = https://dl.bintray.com/git-for-windows/pacman/x86_64 + Server = https://wingit.blob.core.windows.net/x86-64 3. Authorize signing key (this step may have to be repeated occasionally until https://github.com/msys2/msys2/issues/62 is fixed) From 97ea675809ec524f9b3bcc4b23eb1baf8a75b277 Mon Sep 17 00:00:00 2001 From: masterpuma <36850318+masterpuma@users.noreply.github.com> Date: Fri, 30 Mar 2018 17:16:40 -0600 Subject: [PATCH 291/591] Updated Issue reporting guidelines (markdown => rest) --- Issue-reporting-guidelines.md | 11 ----------- Issue-reporting-guidelines.rest | 5 +++++ 2 files changed, 5 insertions(+), 11 deletions(-) delete mode 100644 Issue-reporting-guidelines.md create mode 100644 Issue-reporting-guidelines.rest diff --git a/Issue-reporting-guidelines.md b/Issue-reporting-guidelines.md deleted file mode 100644 index c44e9204942fa3..00000000000000 --- a/Issue-reporting-guidelines.md +++ /dev/null @@ -1,11 +0,0 @@ -* Search the existing [open](https://github.com/git-for-windows/git/issues?q=is%3Aopen) and [closed](https://github.com/git-for-windows/git/issues?q=is%3Aclosed) issues. Maybe the bug was already reported? -* Include the output of git --version and the Windows version. In case the issue might depend on the server include its git version and Windows version also. Of course, if you use a 32-bit Windows or 32-bit Git on a 64-bit Windows, you really want to mention that, too. -* Mention what options you chose when installing Git for Windows, what console window you use (if any), anything that will make it easier to understand what exactly you tried. -* If your setup is different from "normal" setups in any way, it is a good idea to put specifics about that into your bug report, too. -* Describe your issue properly. If you spend 30 seconds throwing out a sloppy report, do expect that others will spend exactly the same amount on trying to resolve it. In contrast, if you write a complete and pleasantly informative bug report, you will almost certainly be rewarded by excellent help with your problem. -* Include a [Minimal, Complete, and Verifiable example](http://stackoverflow.com/help/mcve) using GitHub Markdown's `codeblock` delimiters. -* If your issue stems from a particular repository include its URL. If the repository is proprietary try to create a public test repository showing the same issue. -* Be prepared to test fixes! -* Be polite. You are asking highly competent software developers for help, for free, so you might want to avoid treating them as if they were a commodity or at your free disposal. -* An example for an outstanding report can be found [here](https://github.com/msysgit/msysgit/issues/206#issuecomment-44574988). You may want to imitate the level of detail. -* For further inspiration, read reports that were resolved successfully, http://www.chiark.greenend.org.uk/~sgtatham/bugs.html, http://stackoverflow.com/questions/how-to-ask and http://whathaveyoutried.com/. \ No newline at end of file diff --git a/Issue-reporting-guidelines.rest b/Issue-reporting-guidelines.rest new file mode 100644 index 00000000000000..1d7475839f8c8e --- /dev/null +++ b/Issue-reporting-guidelines.rest @@ -0,0 +1,5 @@ + +* If your issue stems from a particular repository include its URL. If the repository is proprietary try +* Be prepared to test fixes! +* Be polite. You are asking highly competent software developers for help, for free, so you might want to avoid treating them as if they were a commodity or You may want to imitate the level of detail. + From 5dddcadb2260b98344f07e39dd97b40bec01cf2b Mon Sep 17 00:00:00 2001 From: David Macek Date: Fri, 6 Apr 2018 16:52:38 +0200 Subject: [PATCH 292/591] Describe only 64-bit installation (it was wrong for 32-bit anyway); fix URL; fix typos --- Install-inside-MSYS2-proper.md | 15 +++++---------- 1 file changed, 5 insertions(+), 10 deletions(-) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index 56208a9ca517a2..1ef1fddf9e31d1 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -1,4 +1,4 @@ -**This guide assumes that you want the 64-bit version of Git for Windows. To install the 32-bit version, replace the `x86_64` infix by `i686` in every command included in this document.** +**This guide assumes that you want the 64-bit version of Git for Windows.** Git for Windows being based on `MSYS2`, it's possible to install the `git` package into an existing `MSYS2` installation. That means that if you are already using `MSYS2` on your computer, you can use Git for Windows without running the full installer or using the portable version. @@ -10,18 +10,13 @@ Here the steps to take: 2. Edit `/etc/pacman.conf` and just before `[mingw32]` (line #71 on my machine), add the `git-for-windows` packages repository: [git-for-windows] - Server = https://wingit.blob.core.windows.net/$arch + Server = https://wingit.blob.core.windows.net/x86-64 -and optionally also the MINGW-only repository for the *opposite* architecture (i.e. MINGW32 for 64-bit SDK, MINGW64 for 32-bit SDK): +and optionally also the MINGW-only repository for the *opposite* architecture (i.e. MINGW32 for 64-bit SDK): [git-for-windows-mingw32] Server = https://wingit.blob.core.windows.net/i686 -or - - [git-for-windows-mingw64] - Server = https://wingit.blob.core.windows.net/x86-64 - 3. Authorize signing key (this step may have to be repeated occasionally until https://github.com/msys2/msys2/issues/62 is fixed) curl -L https://raw.githubusercontent.com/git-for-windows/build-extra/master/git-for-windows-keyring/git-for-windows.gpg | @@ -32,7 +27,7 @@ or pacboy update - 5. This implicitly updates `msys2-runtime` and therefore will ask you to close the window (*not* just exit the pacman process). Don't panic, simply close all currently open shells and and program relying on `MSYS2` runtime. Once all close, start a new terminal again. + 5. This updates `msys2-runtime` and therefore will ask you to close the window (*not* just exit the pacman process). Don't panic, simply close all currently open MSYS2 shells and MSYS2 programs. Once all are closed, start a new terminal again. 6. Then synchronize *again* (updating the non-core part of the packages): @@ -42,4 +37,4 @@ or pacboy sync git:x git-doc-html:x git-doc-man:x git-extra: curl:x - 8. Finally, check that everything went well by doing `git --version` and it should output something like `git version 2.14.1.windows.1` (or newer). + 8. Finally, check that everything went well by doing `git --version` in a MINGW64 shell and it should output something like `git version 2.14.1.windows.1` (or newer). From cad4ab0fc7d8a2637a90cf861cee6ee53f27ccc3 Mon Sep 17 00:00:00 2001 From: David Macek Date: Fri, 6 Apr 2018 16:55:17 +0200 Subject: [PATCH 293/591] Fix formatting (MSYS2 is a name, not a keyword or an identifier) --- Install-inside-MSYS2-proper.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index 1ef1fddf9e31d1..bed9a152f7c581 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -1,12 +1,12 @@ **This guide assumes that you want the 64-bit version of Git for Windows.** -Git for Windows being based on `MSYS2`, it's possible to install the `git` package into an existing `MSYS2` installation. That means that if you are already using `MSYS2` on your computer, you can use Git for Windows without running the full installer or using the portable version. +Git for Windows being based on MSYS2, it's possible to install the `git` package into an existing MSYS2 installation. That means that if you are already using MSYS2 on your computer, you can use Git for Windows without running the full installer or using the portable version. -Note however that there are some caveats for going this way. Git for Windows created some patches for `msys2-runtime` that have not been sent upstream. (This had been planned, but it was determined in issue [#284](/git-for-windows/git/issues/284) that it would probably not be happening.) This means that you have to install Git for Windows customized `msys2-runtime` to have a fully working `git` inside `MSYS2`. +Note however that there are some caveats for going this way. Git for Windows created some patches for `msys2-runtime` that have not been sent upstream. (This had been planned, but it was determined in issue [#284](/git-for-windows/git/issues/284) that it would probably not be happening.) This means that you have to install Git for Windows customized `msys2-runtime` to have a fully working `git` inside MSYS2. Here the steps to take: - 1. Open an `MSYS2` terminal. + 1. Open an MSYS2 terminal. 2. Edit `/etc/pacman.conf` and just before `[mingw32]` (line #71 on my machine), add the `git-for-windows` packages repository: [git-for-windows] From 1c3ce796be424c3288e942f44db6c0cd485145f6 Mon Sep 17 00:00:00 2001 From: Orgad Shaneh Date: Tue, 24 Apr 2018 08:33:52 +0300 Subject: [PATCH 294/591] Case typo --- Building-msys2-runtime.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Building-msys2-runtime.md b/Building-msys2-runtime.md index a897341e69c9c1..35ffb977858813 100644 --- a/Building-msys2-runtime.md +++ b/Building-msys2-runtime.md @@ -18,7 +18,7 @@ When there are bugs in the msys2-runtime (e.g. problems with the POSIX-to-Windows path mangling), you need to rebuild the `msys-2.0.dll`, possibly frequently. -To rebuild the `msys-2.0.dll` -- assuming that you have built it already as described above -- you first need to start an *MSys* shell by double-clicking the `msys2_shell.cmd` script in your Git SDK's top-level directory. Then call `cd /usr/src/MSYs2-packagess/msys2-runtime/src/msys2-runtime/winsup/cygwin`. Now you can modify the source code to your heart's extent. It is actually a local clone of https://github.com/git-for-windows/msys2-runtime; you probably want to add your own fork as a remote. +To rebuild the `msys-2.0.dll` -- assuming that you have built it already as described above -- you first need to start an *MSys* shell by double-clicking the `msys2_shell.cmd` script in your Git SDK's top-level directory. Then call `cd /usr/src/MSYS2-packagess/msys2-runtime/src/msys2-runtime/winsup/cygwin`. Now you can modify the source code to your heart's extent. It is actually a local clone of https://github.com/git-for-windows/msys2-runtime; you probably want to add your own fork as a remote. To actually build the `msys-2.0.dll`, switch to `src/build--pc-msys/-pc-msys/winsup/cygwin` and type `make`. This will generate an `msys0.dll` file in that directory. This is the new `msys-2.0.dll`, but you cannot simply copy it into `/usr/bin/` because it is in use by the current `mintty` as well as by the current Bash. To update, you need to close all programs using the msys2-runtime (including all of the terminal windows), then copy the `msys0.dll` file, replacing the existing `/usr/bin/msys-2.0.dll`, either using Explorer, `cmd.exe` or a separate Git SDK (for example, when debugging the 64-bit msys2-runtime, a 32-bit Git SDK comes in real handy). You will **want** to make a backup copy of the old `msys-2.0.dll`... From 313a02a97605a53f43d4971bdbae913d92a309df Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Sun, 29 Apr 2018 14:57:22 +0200 Subject: [PATCH 295/591] Describe the release cadence of Git for Windows --- FAQ.md | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/FAQ.md b/FAQ.md index 8ad3174e02a4d4..c19eae3544d010 100644 --- a/FAQ.md +++ b/FAQ.md @@ -29,6 +29,17 @@ In general, yes: it is a good idea to stay up-to-date. If you have a version older than 2.14.1, it is *highly* advisable to upgrade. These versions fixed critical bugs, therefore sticking with older Git for Windows versions makes you vulnerable: 2.14.1, 2.7.4, 2.7.0, 2.6.1, 2.5.2, 1.9.5-preview20150319, and 1.9.5-preview20141217. +## What is the release cadence of Git for Windows? + +Official Git for Windows versions mainly follow Git's release cycle: every 12 weeks or so, a new major Git version is released (see details here: http://tinyurl.com/gitCal). Typically, Git for Windows will follow suit within a day. + +Other than that, Git for Windows follows the *newest* Git version's maintenance releases (read: after Git for Windows v2.15.0 was released, no new Git for Windows v2.14.x version would be released). Indicators for imminent maintenance releases of Git are: + +- The Git maintainer sometimes talks about this in the preamble of the ["What's cooking in git.git" mails](https://public-inbox.org/git/?q=s%3A%22what%27s+cooking%22+AND+f%3Agitster%40pobox.com). +- The [`maint` in git.git](https://github.com/git/git/commits/maint) accumulates critical patches. + +Finally, Git for Windows is sometimes released in "out-of-band" versions, when critical fixes specific to Git for Windows necessitate it. These out-of-band versions are indicated by appending a `(2)` to the latest release (or `(3)`, `(4)`, etc). Examples for such out-of-band versions include: [Git for Windows v2.15.1(2)](https://github.com/git-for-windows/git/releases/tag/v2.15.1.windows.2) and [Git for Windows v2.16.1(4)](https://github.com/git-for-windows/git/releases/tag/v2.16.1.windows.4). + ## What is the relationship between *Git for Windows* and *msysGit*? *Git for Windows* used to be developed using the development environment called "msysGit", but roughly coinciding with Git 2.1, msysGit was superseded by a new development environment: the [Git for Windows SDK](https://github.com/git-for-windows/build-extra/releases). See [here](https://github.com/git-for-windows/git/wiki/Updating-your-SDK) to get a copy. From ddc7afe99c681554f0da2864862eabea381b53c7 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Sun, 29 Apr 2018 14:58:24 +0200 Subject: [PATCH 296/591] Fix another tyop --- Building-msys2-runtime.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Building-msys2-runtime.md b/Building-msys2-runtime.md index 35ffb977858813..72daa3cb072f63 100644 --- a/Building-msys2-runtime.md +++ b/Building-msys2-runtime.md @@ -18,7 +18,7 @@ When there are bugs in the msys2-runtime (e.g. problems with the POSIX-to-Windows path mangling), you need to rebuild the `msys-2.0.dll`, possibly frequently. -To rebuild the `msys-2.0.dll` -- assuming that you have built it already as described above -- you first need to start an *MSys* shell by double-clicking the `msys2_shell.cmd` script in your Git SDK's top-level directory. Then call `cd /usr/src/MSYS2-packagess/msys2-runtime/src/msys2-runtime/winsup/cygwin`. Now you can modify the source code to your heart's extent. It is actually a local clone of https://github.com/git-for-windows/msys2-runtime; you probably want to add your own fork as a remote. +To rebuild the `msys-2.0.dll` -- assuming that you have built it already as described above -- you first need to start an *MSys* shell by double-clicking the `msys2_shell.cmd` script in your Git SDK's top-level directory. Then call `cd /usr/src/MSYS2-packages/msys2-runtime/src/msys2-runtime/winsup/cygwin`. Now you can modify the source code to your heart's extent. It is actually a local clone of https://github.com/git-for-windows/msys2-runtime; you probably want to add your own fork as a remote. To actually build the `msys-2.0.dll`, switch to `src/build--pc-msys/-pc-msys/winsup/cygwin` and type `make`. This will generate an `msys0.dll` file in that directory. This is the new `msys-2.0.dll`, but you cannot simply copy it into `/usr/bin/` because it is in use by the current `mintty` as well as by the current Bash. To update, you need to close all programs using the msys2-runtime (including all of the terminal windows), then copy the `msys0.dll` file, replacing the existing `/usr/bin/msys-2.0.dll`, either using Explorer, `cmd.exe` or a separate Git SDK (for example, when debugging the 64-bit msys2-runtime, a 32-bit Git SDK comes in real handy). You will **want** to make a backup copy of the old `msys-2.0.dll`... From 68871ee95d3e799ad17ff3223dc246d7020bda06 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Sun, 29 Apr 2018 15:00:33 +0200 Subject: [PATCH 297/591] Revert "Updated Issue reporting guidelines (markdown => rest)" We don't use .rest in Git for Windows, and the reverted commit inadvertently removed half of the useful information. This reverts commit 97ea675809ec524f9b3bcc4b23eb1baf8a75b277. Signed-off-by: Johannes Schindelin --- Issue-reporting-guidelines.md | 11 +++++++++++ Issue-reporting-guidelines.rest | 5 ----- 2 files changed, 11 insertions(+), 5 deletions(-) create mode 100644 Issue-reporting-guidelines.md delete mode 100644 Issue-reporting-guidelines.rest diff --git a/Issue-reporting-guidelines.md b/Issue-reporting-guidelines.md new file mode 100644 index 00000000000000..c44e9204942fa3 --- /dev/null +++ b/Issue-reporting-guidelines.md @@ -0,0 +1,11 @@ +* Search the existing [open](https://github.com/git-for-windows/git/issues?q=is%3Aopen) and [closed](https://github.com/git-for-windows/git/issues?q=is%3Aclosed) issues. Maybe the bug was already reported? +* Include the output of git --version and the Windows version. In case the issue might depend on the server include its git version and Windows version also. Of course, if you use a 32-bit Windows or 32-bit Git on a 64-bit Windows, you really want to mention that, too. +* Mention what options you chose when installing Git for Windows, what console window you use (if any), anything that will make it easier to understand what exactly you tried. +* If your setup is different from "normal" setups in any way, it is a good idea to put specifics about that into your bug report, too. +* Describe your issue properly. If you spend 30 seconds throwing out a sloppy report, do expect that others will spend exactly the same amount on trying to resolve it. In contrast, if you write a complete and pleasantly informative bug report, you will almost certainly be rewarded by excellent help with your problem. +* Include a [Minimal, Complete, and Verifiable example](http://stackoverflow.com/help/mcve) using GitHub Markdown's `codeblock` delimiters. +* If your issue stems from a particular repository include its URL. If the repository is proprietary try to create a public test repository showing the same issue. +* Be prepared to test fixes! +* Be polite. You are asking highly competent software developers for help, for free, so you might want to avoid treating them as if they were a commodity or at your free disposal. +* An example for an outstanding report can be found [here](https://github.com/msysgit/msysgit/issues/206#issuecomment-44574988). You may want to imitate the level of detail. +* For further inspiration, read reports that were resolved successfully, http://www.chiark.greenend.org.uk/~sgtatham/bugs.html, http://stackoverflow.com/questions/how-to-ask and http://whathaveyoutried.com/. \ No newline at end of file diff --git a/Issue-reporting-guidelines.rest b/Issue-reporting-guidelines.rest deleted file mode 100644 index 1d7475839f8c8e..00000000000000 --- a/Issue-reporting-guidelines.rest +++ /dev/null @@ -1,5 +0,0 @@ - -* If your issue stems from a particular repository include its URL. If the repository is proprietary try -* Be prepared to test fixes! -* Be polite. You are asking highly competent software developers for help, for free, so you might want to avoid treating them as if they were a commodity or You may want to imitate the level of detail. - From 64bc39d9ccf5d11a83094cb73e9698ed6c5e2946 Mon Sep 17 00:00:00 2001 From: Clemens Buchacher Date: Tue, 1 May 2018 21:47:54 +0200 Subject: [PATCH 298/591] disable ASLR --- Debugging-Git.md | 12 +++++++++++- 1 file changed, 11 insertions(+), 1 deletion(-) diff --git a/Debugging-Git.md b/Debugging-Git.md index 53d7c5a6828850..73d16993c79c34 100644 --- a/Debugging-Git.md +++ b/Debugging-Git.md @@ -3,7 +3,17 @@ First of all, Git's `.exe` files should be rebuilt with debugging information, and without optimization (because `gdb` has serious troubles single-stepping code compiled using `-O2` for some reason). To this end: 1. [install the Git for Windows SDK](https://gitforwindows.org/#download-sdk) -2. edit `/usr/src/git/Makefile` to remove the `-O2` from the `CFLAGS = -g -O2 -Wall` line, +2. Create `/usr/src/git/config.mak` with the following contents to disable compiler optimization and ASLR: + +``` +DEVELOPER=1 +ifndef NDEBUG +CFLAGS := $(filter-out -O2,$(CFLAGS)) +ASLR_OPTION := -Wl,--dynamicbase +BASIC_LDFLAGS := $(filter-out $(ASLR_OPTION),$(BASIC_LDFLAGS)) +endif +``` + 3. run `make` in `/usr/src/git/`. After that, you can run Git's executables in GDB like so: From 83771f3904f2a4893e27e45b623328c631fa29d1 Mon Sep 17 00:00:00 2001 From: Kim Sullivan Date: Wed, 2 May 2018 15:23:08 +0200 Subject: [PATCH 299/591] clarify the installer has to be explicitly run as administrator --- Technical-overview.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Technical-overview.md b/Technical-overview.md index 6323808df7117d..8e08b3a94e2527 100644 --- a/Technical-overview.md +++ b/Technical-overview.md @@ -6,7 +6,7 @@ The process to build installer is made easy via the `Git for Windows SDK`. The s # Installing the SDK -Download the [SDK](https://gitforwindows.org/#download-sdk) and run it. You will end up with a console window running the `Git for Windows SDK` shell, which you can use for the next steps. Git is already checked out and the latest version build and installed, so if you just want to build an installer from latest master, you are ready to go. +Download the [SDK](https://gitforwindows.org/#download-sdk) and run it (using "Run as Administrator"). You will end up with a console window running the `Git for Windows SDK` shell, which you can use for the next steps. Git is already checked out and the latest version build and installed, so if you just want to build an installer from latest master, you are ready to go. You can open the `Git for Windows SDK` shell by double clicking `git-bash.exe` in the install folder. From 097b79b179adfeab1fb8163cd7810e4753c04dac Mon Sep 17 00:00:00 2001 From: Kim Sullivan Date: Thu, 3 May 2018 07:46:28 +0200 Subject: [PATCH 300/591] Added step to fetch latest sources as per https://github.com/git-for-windows/git/issues/1660 --- Technical-overview.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Technical-overview.md b/Technical-overview.md index 8e08b3a94e2527..98525204d3f4f1 100644 --- a/Technical-overview.md +++ b/Technical-overview.md @@ -6,7 +6,7 @@ The process to build installer is made easy via the `Git for Windows SDK`. The s # Installing the SDK -Download the [SDK](https://gitforwindows.org/#download-sdk) and run it (using "Run as Administrator"). You will end up with a console window running the `Git for Windows SDK` shell, which you can use for the next steps. Git is already checked out and the latest version build and installed, so if you just want to build an installer from latest master, you are ready to go. +Download the [SDK](https://gitforwindows.org/#download-sdk) and run it (using "Run as Administrator"). You will end up with a console window running the `Git for Windows SDK` shell, which you can use for the next steps. You need to fetch the latest version of the Git sources - just run the command `sdk install git`. After that, if you just want to build an installer from latest master, you are ready to go. You can open the `Git for Windows SDK` shell by double clicking `git-bash.exe` in the install folder. From 51a79907f579f64e1c051cd1208638044b7ab6ed Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Fri, 4 May 2018 12:58:56 +0200 Subject: [PATCH 301/591] Describe the sleep-in-a-loop trick to allow attaching gdb to processes when it is not possible to start them in gdb right away. --- Debugging-Git.md | 23 +++++++++++++++++++++++ 1 file changed, 23 insertions(+) diff --git a/Debugging-Git.md b/Debugging-Git.md index 73d16993c79c34..7e57a71a3585bd 100644 --- a/Debugging-Git.md +++ b/Debugging-Git.md @@ -33,6 +33,29 @@ b die_builtin before calling `run` in `gdb` to stop execution at the appropriate time. +## Debugging bugs with redirected stdin + +When standard input is redirected (e.g. `echo "Hello" | gdb -args git ...`), `gdb` will not be able to receive your commands, and therefore you cannot debug. One little trick to get around this is to insert debug statements into the C code such as: + +```c +{ + int ddd = 1; + fprintf(stderr, "Waiting for gdb on pid %d", (int)getpid()); + while (ddd) + sleep(1); +} +``` + +When running this (without prefixing the command with `gdb -args`), it will print the process ID and then wait. To attach `gdb` to this process, simply call + +``` +gdb git +``` + +then use `gdb`'s `up` command until you are in that loop, and call `set ddd = 0` and `continue` after setting whatever breakpoints you want to set. Or call `finish` until the point where you want to single-step (`u` to single-step, `s` to single-step into called functions). + +The same trick also helps with debugging processes that are spawned from processes that are spawned from the main process. + ## Debugging crashes (segmentation faults) When a command crashes (i.e. throws a segmentation fault), running it in `gdb` as described above will stop when the command crashes. Once that is the case, you can obtain a back trace with `bt`. Example: From 23bdd3258db49d2322bddb48f9e075f3fe3d00ec Mon Sep 17 00:00:00 2001 From: Olga Telezhnaya Date: Mon, 7 May 2018 11:50:39 +0300 Subject: [PATCH 302/591] Add some tips how to deal with build errors. --- FAQ.md | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/FAQ.md b/FAQ.md index c19eae3544d010..ee1d0b41f9a4ec 100644 --- a/FAQ.md +++ b/FAQ.md @@ -94,6 +94,13 @@ Some developers want to start git-bash (of Git for Windows SDK) with a different To achieve this in windows following command could be placed inside the launcher: `C:\Windows\System32\cmd.exe /c "set LANG=en_GB && start C:\git-sdk-64\git-bash.exe && exit"` replace `en_GB` with your preferred locale. + +## I have errors while building the solution in Visual studio +(i.e. `fatal error C1083: Cannot open include file: 'openssl/ssl.h': No such file or directory`) + +Try to open the console and invoke `git\compat\vcbuild\vcpkg_install.bat`. Make sure that it has completed successfully, then clean and rebuild the solution. + +Ensure also that you are using proper Build Tools (v140). It's going by default in VS 2015. If you are using VS 2017, you need to install them manually. Do not upgrade the project to v141 - it can't be done automatically. ## Licenses From f6244fbd6e6c77e38b1df312e46cc706ac992f1d Mon Sep 17 00:00:00 2001 From: Olga Telezhnaya Date: Mon, 7 May 2018 11:54:40 +0300 Subject: [PATCH 303/591] Add a comment about Build Tools. --- Compiling-Git-with-Visual-Studio.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Compiling-Git-with-Visual-Studio.md b/Compiling-Git-with-Visual-Studio.md index b1bc0f71be9300..67d8890f5f9ef1 100644 --- a/Compiling-Git-with-Visual-Studio.md +++ b/Compiling-Git-with-Visual-Studio.md @@ -6,7 +6,7 @@ Git's source code (and hence also Git for Windows' source code) is [usually buil However, as of Git for Windows v2.11.0, a much more convenient way is available: by cloning https://github.com/git-for-windows/git and checking out the `vs/master` branch, you will automatically have project definitions ready to go with Visual Studio. -Simply open the `git.sln` file and build the solution. +Simply open the `git.sln` file and build the solution. DO NOT upgrade Build Tools to v141 - it will not work. If you are using VS 2017 or later, you need to install Build Tools v140 manually. # Running the tests From e9effcfc71abc50388681f32a22a65745f79b422 Mon Sep 17 00:00:00 2001 From: Olga Telezhnaya Date: Mon, 21 May 2018 22:30:54 +0300 Subject: [PATCH 304/591] Add explanations about real practical difference between MSYS2 and MINGW --- The-difference-between-MINGW-and-MSYS2.md | 38 +++++++++++++++++++++-- 1 file changed, 36 insertions(+), 2 deletions(-) diff --git a/The-difference-between-MINGW-and-MSYS2.md b/The-difference-between-MINGW-and-MSYS2.md index e08ea7a39e2955..65f2457494cf97 100644 --- a/The-difference-between-MINGW-and-MSYS2.md +++ b/The-difference-between-MINGW-and-MSYS2.md @@ -1,6 +1,6 @@ # tl;dr -MINGW refers to executables that are compiled using the GNU C Compiler but target the Win32 API. MSYS2 refers to executables that are compiled (another) GNU C Compiler and make use of a POSIX emulation layer. +MINGW refers to executables that are compiled using the MINGW GCC Compiler and target the Win32 API. MSYS2 refers to executables that are compiled by MSYS2 GCC Compiler and make use of a POSIX emulation layer. # Background @@ -24,4 +24,38 @@ MSYS2 also ported the Pacman package management system from Arch Linux and uses MSYS2 is also *very* active, typically providing package updates multiple times per week. -It still required a two-month effort to bring everything to a state where Git's test suite passes, many more months until the first official Git for Windows 2.x was released, and a couple of patches still await their submission to the respective upstream projects. Yet without MSYS2, the modernization of Git for Windows would simply not have happened. \ No newline at end of file +It still required a two-month effort to bring everything to a state where Git's test suite passes, many more months until the first official Git for Windows 2.x was released, and a couple of patches still await their submission to the respective upstream projects. Yet without MSYS2, the modernization of Git for Windows would simply not have happened. + +# Difference between MSYS2 and MINGW: going into details + +In order to support Git fully, Git for Windows needs a way to execute the shell scripts that are *still* a core part of Git. +To do so, we use a stripped-down MSYS2 (which in turn is a modified version of Cygwin - [read more here](https://github.com/msys2/msys2/wiki/How-does-MSYS2-differ-from-Cygwin)). + +Now, to understand the packages' names better, we need to understand how MSYS2 packages are compared to MINGW packages. + +MSYS2's runtime is `\usr\bin\msys-2.0.dll`. It is an implicit dependency of all MSYS2 executables (most of which live in \usr\bin). This runtime provides emulation for all POSIX functionality enjoyed e.g. by Linux software. This means that it is *a lot* easier to port Linux projects to MSYS2 than it is to straight Windows. So when porting Bash or OpenSSH, it is much, much easier to port them to an MSYS2 package. + +So why don't we just make all packages MSYS2 ones? The POSIX emulation is *slow*. Like, really, really noticeably slow. +So it is much preferred to port Linux software to pure Win32 calls, without going the POSIX emulation route. Of course, this is a ton more work *per project*. That is the reason why this is not done for all packages. + +Normally, we use Visual C++ compiler on Windows. When building Windows software using GCC, it is necessary to have all the support headers and libraries. They are not provided by Microsoft, but by a separate project called MINGW ("Minimal GNU on Windows"). MSYS2 uses these MINGW libraries (and MINGW GCC compiler) to build pure Win32 packages, and those are called MINGW packages. + +That is the difference between `\usr\src\MSYS2-packages` and `\usr\src\MINGW-packages`. To discern those packages from one another, the MINGW packages all start with the prefix `mingw-w64-`. + + +# It was too simple +To make things even more complicated, remember that you can run 32-bit executables from a 64-bit process and vice versa (provided that you are on a 64-bit Windows). This is only *partially* supported by MSYS2: while you can mix and match 32-bit/64-bit MINGW processes, the same is *not* true of MSYS2 processes, as they are limited by the "bit-ness" of the MSYS2 runtime. + +A 64-bit MSYS2 process always uses the 64-bit MSYS2 runtime, and this runtime needs to be shared between all child MSYS2 processes, to share information required to emulate e.g. POSIX signal handling. That means that you can install only 32-bit MSYS2 packages into a 32-bit MSYS2 setup. + +So when you try to upgrade Bash in a 32-bit Git for Windows SDK (which is a slightly modified version of MSYS2, specifically crafted to support Git for Windows' development), it is clear that `pacman -Sy bash` will only upgrade a 32-bit Bash, not a 64-bit one. + +However, if you want to install a 32-bit *MINGW* package, you have to be able to discern that from a 64-bit MINGW package. + +For example, you could install MINGW cURL in both 32-bit and 64-bit versions. To enable that, there is a further convention that the MINGW packages have not only the prefix `mingw-w64-` but also the infix `i686-` for 32-bit, and `x86_64-` for 64-bit packages. The 32-bit MINGW cURL is offered, therefore, in the `mingw-w64-i686-curl` package, the 64-bit one in `mingw-w64-x86_64-curl`. + +To allow for side-by-side installation, the 32-bit MINGW files are installed into the `\mingw32` root, the 64-bit ones into `\mingw64`. Hence, the 64-bit curl.exe lives in `\mingw64\bin\curl.exe`. Git for Windows wants to be as fast as possible, so git.exe is compiled as a MINGW executable. + +Therefore, it lives in `\mingw64\bin\git.exe` (or in `\mingw32\bin\git.exe`), and is bundled in the `mingw-w64-x86_64-git` (or `mingw-w64-i686-git`) package. (That's not the complete truth for documentation and testing packages, but let's concentrate on the main story.) + +Pacman (package manager used by MSYS2) has this feature where it regularly adds its own modifications on top of the original source of packages. In Git's case, it adds e.g. the git-wrapper in its various forms, and more. The git-wrapper is pretty specific to the official Git for Windows that is based on MSYS2, though (while we have a task to support both MSys and MSYS2 packages). So it cannot live in git-for-windows/git. It lives in MINGW-packages, in the subdirectory specific to the mingw-w64-git package. \ No newline at end of file From 44885c6ce7e65caf5e9f7a119458b4c2394aabfb Mon Sep 17 00:00:00 2001 From: Olga Telezhnaya Date: Wed, 23 May 2018 11:43:15 +0300 Subject: [PATCH 305/591] add article about fork on Windows --- ...()---CreateProcess()-:-Windows-vs-Linux.md | 38 +++++++++++++++++++ 1 file changed, 38 insertions(+) create mode 100644 fork()---exec()---CreateProcess()-:-Windows-vs-Linux.md diff --git a/fork()---exec()---CreateProcess()-:-Windows-vs-Linux.md b/fork()---exec()---CreateProcess()-:-Windows-vs-Linux.md new file mode 100644 index 00000000000000..9657e711d16428 --- /dev/null +++ b/fork()---exec()---CreateProcess()-:-Windows-vs-Linux.md @@ -0,0 +1,38 @@ +# tl ; dr + +You need to make 2 calls to create new process in Linux: `fork()` and then `exec()`. Windows has only one: `CreateProcess()`. Architecture differs so much, that's why it was so hard to implement `fork()` on Windows, and it still works dramatically slower. Please think twice before using `fork()` on Windows, and do not use `fork()` + `exec()`: you are doing tons of useless job, you have `CreateProcess()` for it. + +## Before start + +All information about Linux is a brief retelling of Robert Love's book: Linux Kernel Development. +I definitely recommend to read this book by yourself, especially if this article wasn't enough for you. I will oversimplify, otherwise I need to put whole book here. + +# Process vs thread + +In Windows, process is a container for threads, while thread is an executing instance of program with corresponding resources. Process can have any number of threads that you want. 0 threads is possible, but useless; many threads give an opportunity to make multithreading application. All threads in one process share same piece of memory and need to use synchronisation mechanisms. + +In Linux, there is no difference between process and thread. They use virtual processor (it's exclusive for each process/thread) and virtual memory (it's shared). Virtual processor gives an illusion that every process/thread has its own real processor for all its needs, while in fact they use the processor by turns. Virtual memory also gives an illusion that process/thread has all available memory in the system (shared with other connected processes/threads), while in fact it's just a piece of memory for this group. + +# Copy-on-write + +COW is a general mechanism that allows avoiding copying while we do not need it. It's easier to explain this awesome mechanism with example from life. Imagine you have a great paper book, and your friends want to read it with you. Moreover, all of you want to make notes while reading. Naive solution is to make N full copies of the book for all readers, and then read each copy and make notes. But COW offers you to read the same book, and make the notes in your own notebook: you can copy little pieces if you want, but you don't need to make full copy. So, every reader owns the notebook, but you have only 1 book for all: it is enough. It allows to save time dramatically. + +# Linux internals: fork(), exec() + +`fork()` creates new process from existing one using COW. So, `fork()` makes a copy of the process, but you need to understand that there is almost no copying at all because of COW. + +`exec()` puts the executable into new process and starts to execute it. + +Is is super important moment: we do not only save time by COW; we save it in high-loaded moment. Everyone wants to start their new task immediately, without any waiting. Additionally, there is a big chance that we will never copy all this parent's stuff: it's a common scenario when we do not need it at all. + +# Windows internals: why fork() does not work as native + +Actually, we have enough information to guess the reason. + +At first, process on Windows and on Linux means different things: we need to create both process and at least one thread to start executing smth on Windows. COW can't be done without headache because of different ways of working with memory. We also have tons of other problems that are behind the scene for this article. + +In short, *All* programs linking to the MSYS2 runtime essentially perform the check "was I just forked?" at startup. If that is the case, the regular code path is completely disabled and a special "fork mode" is spun up. + +As a result, it really copies the entire address accessible space of the original process. It tries as best as it can to open the original file descriptors and sockets. It reinstates the current working directory (even if it does not exist anymore). And it does this and that, and that and this, and basically spends a whole lot of time that Linux' kernel would give the programs for free. + +All of this was useless if you use `exec()` after it. You have `CreateProcess()` that was created as a part of Windows platform, and it is optimized to be fast enough. \ No newline at end of file From e6ce1cb662f45985e5d1a90f2a5415407e98c80b Mon Sep 17 00:00:00 2001 From: Olga Telezhnaya Date: Wed, 23 May 2018 11:52:10 +0300 Subject: [PATCH 306/591] Updated fork() exec() CreateProcess() : Windows vs Linux (markdown) From 72054c6247a7cccd1bf02fd537f42df103edadb3 Mon Sep 17 00:00:00 2001 From: Olga Telezhnaya Date: Wed, 23 May 2018 11:54:35 +0300 Subject: [PATCH 307/591] Add link to the book about Linux --- ...x.md => fork(),-exec(),-CreateProcess():-Windows-vs-Linux.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) rename fork()---exec()---CreateProcess()-:-Windows-vs-Linux.md => fork(),-exec(),-CreateProcess():-Windows-vs-Linux.md (96%) diff --git a/fork()---exec()---CreateProcess()-:-Windows-vs-Linux.md b/fork(),-exec(),-CreateProcess():-Windows-vs-Linux.md similarity index 96% rename from fork()---exec()---CreateProcess()-:-Windows-vs-Linux.md rename to fork(),-exec(),-CreateProcess():-Windows-vs-Linux.md index 9657e711d16428..bcde682aa1f9e2 100644 --- a/fork()---exec()---CreateProcess()-:-Windows-vs-Linux.md +++ b/fork(),-exec(),-CreateProcess():-Windows-vs-Linux.md @@ -4,7 +4,7 @@ You need to make 2 calls to create new process in Linux: `fork()` and then `exec ## Before start -All information about Linux is a brief retelling of Robert Love's book: Linux Kernel Development. +All information about Linux is a brief retelling of Robert Love's book: [Linux Kernel Development](https://doc.lagout.org/operating%20system%20/linux/Linux%20Kernel%20Development%2C%203rd%20Edition.pdf). I definitely recommend to read this book by yourself, especially if this article wasn't enough for you. I will oversimplify, otherwise I need to put whole book here. # Process vs thread From 8917eb5c7ea5b4ab9700b1724bd484ba7c2bde41 Mon Sep 17 00:00:00 2001 From: Olga Telezhnaya Date: Wed, 23 May 2018 12:02:18 +0300 Subject: [PATCH 308/591] Add more links --- fork(),-exec(),-CreateProcess():-Windows-vs-Linux.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/fork(),-exec(),-CreateProcess():-Windows-vs-Linux.md b/fork(),-exec(),-CreateProcess():-Windows-vs-Linux.md index bcde682aa1f9e2..601a545ccc035a 100644 --- a/fork(),-exec(),-CreateProcess():-Windows-vs-Linux.md +++ b/fork(),-exec(),-CreateProcess():-Windows-vs-Linux.md @@ -1,6 +1,6 @@ # tl ; dr -You need to make 2 calls to create new process in Linux: `fork()` and then `exec()`. Windows has only one: `CreateProcess()`. Architecture differs so much, that's why it was so hard to implement `fork()` on Windows, and it still works dramatically slower. Please think twice before using `fork()` on Windows, and do not use `fork()` + `exec()`: you are doing tons of useless job, you have `CreateProcess()` for it. +You need to make 2 calls to create new process in Linux: [`fork()`](http://man7.org/linux/man-pages/man2/fork.2.html) and then [`exec()`](http://man7.org/linux/man-pages/man3/exec.3.html). Windows has only one: [`CreateProcess()`](https://msdn.microsoft.com/en-us/library/windows/desktop/ms682425(v=vs.85).aspx). Architecture differs so much, that's why it was so hard to implement `fork()` on Windows, and it still works dramatically slower. Please think twice before using `fork()` on Windows, and do not use `fork()` + `exec()`: you are doing tons of useless job, you have `CreateProcess()` for it. ## Before start @@ -31,7 +31,7 @@ Actually, we have enough information to guess the reason. At first, process on Windows and on Linux means different things: we need to create both process and at least one thread to start executing smth on Windows. COW can't be done without headache because of different ways of working with memory. We also have tons of other problems that are behind the scene for this article. -In short, *All* programs linking to the MSYS2 runtime essentially perform the check "was I just forked?" at startup. If that is the case, the regular code path is completely disabled and a special "fork mode" is spun up. +In short, *All* programs linking to the [MSYS2 runtime](https://github.com/git-for-windows/git/wiki/The-difference-between-MINGW-and-MSYS2) essentially perform the check "was I just forked?" at startup. If that is the case, the regular code path is completely disabled and a special "fork mode" is spun up. As a result, it really copies the entire address accessible space of the original process. It tries as best as it can to open the original file descriptors and sockets. It reinstates the current working directory (even if it does not exist anymore). And it does this and that, and that and this, and basically spends a whole lot of time that Linux' kernel would give the programs for free. From 591c862e253752b1ee582382c8e09c30cd696a82 Mon Sep 17 00:00:00 2001 From: Olga Telezhnaya Date: Wed, 30 May 2018 17:50:50 +0300 Subject: [PATCH 309/591] Add link to diff between MSYS and MINGW --- fork(),-exec(),-CreateProcess():-Windows-vs-Linux.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/fork(),-exec(),-CreateProcess():-Windows-vs-Linux.md b/fork(),-exec(),-CreateProcess():-Windows-vs-Linux.md index 601a545ccc035a..ac9243f330ede8 100644 --- a/fork(),-exec(),-CreateProcess():-Windows-vs-Linux.md +++ b/fork(),-exec(),-CreateProcess():-Windows-vs-Linux.md @@ -7,6 +7,8 @@ You need to make 2 calls to create new process in Linux: [`fork()`](http://man7. All information about Linux is a brief retelling of Robert Love's book: [Linux Kernel Development](https://doc.lagout.org/operating%20system%20/linux/Linux%20Kernel%20Development%2C%203rd%20Edition.pdf). I definitely recommend to read this book by yourself, especially if this article wasn't enough for you. I will oversimplify, otherwise I need to put whole book here. +`fork()` on Windows is emulated by MSYS, while there is no `fork()` in MINGW. That is partially what makes [MSYS much slower than MINGW](https://github.com/git-for-windows/git/wiki/The-difference-between-MINGW-and-MSYS2). + # Process vs thread In Windows, process is a container for threads, while thread is an executing instance of program with corresponding resources. Process can have any number of threads that you want. 0 threads is possible, but useless; many threads give an opportunity to make multithreading application. All threads in one process share same piece of memory and need to use synchronisation mechanisms. From 4bd20c09c95ee649848792325d228fd668f3e5f8 Mon Sep 17 00:00:00 2001 From: Olga Telezhnaya Date: Wed, 30 May 2018 17:56:39 +0300 Subject: [PATCH 310/591] Updated The difference between MINGW and MSYS2 (markdown) --- The-difference-between-MINGW-and-MSYS2.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/The-difference-between-MINGW-and-MSYS2.md b/The-difference-between-MINGW-and-MSYS2.md index 65f2457494cf97..3806a20a1e4c9c 100644 --- a/The-difference-between-MINGW-and-MSYS2.md +++ b/The-difference-between-MINGW-and-MSYS2.md @@ -36,7 +36,7 @@ Now, to understand the packages' names better, we need to understand how MSYS2 p MSYS2's runtime is `\usr\bin\msys-2.0.dll`. It is an implicit dependency of all MSYS2 executables (most of which live in \usr\bin). This runtime provides emulation for all POSIX functionality enjoyed e.g. by Linux software. This means that it is *a lot* easier to port Linux projects to MSYS2 than it is to straight Windows. So when porting Bash or OpenSSH, it is much, much easier to port them to an MSYS2 package. So why don't we just make all packages MSYS2 ones? The POSIX emulation is *slow*. Like, really, really noticeably slow. -So it is much preferred to port Linux software to pure Win32 calls, without going the POSIX emulation route. Of course, this is a ton more work *per project*. That is the reason why this is not done for all packages. +So it is much preferred to port Linux software to pure Win32 calls, without going the POSIX emulation route. Of course, this is a ton more work *per project*. That is the reason why this is not done for all packages. You may want to read [this article](https://github.com/git-for-windows/git/wiki/fork(),-exec(),-CreateProcess():-Windows-vs-Linux) for getting an acquaintance of just a part of underlying problems. Normally, we use Visual C++ compiler on Windows. When building Windows software using GCC, it is necessary to have all the support headers and libraries. They are not provided by Microsoft, but by a separate project called MINGW ("Minimal GNU on Windows"). MSYS2 uses these MINGW libraries (and MINGW GCC compiler) to build pure Win32 packages, and those are called MINGW packages. From 29540e7191c7a9bdef16bffc4dc53592deb24a9b Mon Sep 17 00:00:00 2001 From: "Antoine W. Campagna" Date: Thu, 14 Jun 2018 10:41:12 -0400 Subject: [PATCH 311/591] sdk command to initialize the repository is called init and not install --- Technical-overview.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Technical-overview.md b/Technical-overview.md index 98525204d3f4f1..8a789af2c7e9cf 100644 --- a/Technical-overview.md +++ b/Technical-overview.md @@ -6,7 +6,7 @@ The process to build installer is made easy via the `Git for Windows SDK`. The s # Installing the SDK -Download the [SDK](https://gitforwindows.org/#download-sdk) and run it (using "Run as Administrator"). You will end up with a console window running the `Git for Windows SDK` shell, which you can use for the next steps. You need to fetch the latest version of the Git sources - just run the command `sdk install git`. After that, if you just want to build an installer from latest master, you are ready to go. +Download the [SDK](https://gitforwindows.org/#download-sdk) and run it (using "Run as Administrator"). You will end up with a console window running the `Git for Windows SDK` shell, which you can use for the next steps. You need to fetch the latest version of the Git sources - just run the command `sdk init git`. After that, if you just want to build an installer from latest master, you are ready to go. You can open the `Git for Windows SDK` shell by double clicking `git-bash.exe` in the install folder. From 85fa0c1edab80f868d2b5c94ba282f1751f061b2 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Wed, 20 Jun 2018 13:27:02 +0200 Subject: [PATCH 312/591] Mention that Git for Windows older than v2.17.1(2) is not safe. --- FAQ.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/FAQ.md b/FAQ.md index ee1d0b41f9a4ec..48dd3fb7a939f0 100644 --- a/FAQ.md +++ b/FAQ.md @@ -27,7 +27,7 @@ In the meantime you could try: In general, yes: it is a good idea to stay up-to-date. -If you have a version older than 2.14.1, it is *highly* advisable to upgrade. These versions fixed critical bugs, therefore sticking with older Git for Windows versions makes you vulnerable: 2.14.1, 2.7.4, 2.7.0, 2.6.1, 2.5.2, 1.9.5-preview20150319, and 1.9.5-preview20141217. +If you have a version older than 2.17.1(2), it is *highly* advisable to upgrade. These versions fixed critical bugs, therefore sticking with older Git for Windows versions makes you vulnerable: 2.17.1(2), 2.14.1, 2.7.4, 2.7.0, 2.6.1, 2.5.2, 1.9.5-preview20150319, and 1.9.5-preview20141217. ## What is the release cadence of Git for Windows? From 7f336240d0be11f2fe6256e7f03d99538efb6ace Mon Sep 17 00:00:00 2001 From: Sebastian Schuberth Date: Fri, 13 Jul 2018 12:45:37 +0200 Subject: [PATCH 313/591] Minor correction of navigation paths in the management console. --- Symbolic-Links.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/Symbolic-Links.md b/Symbolic-Links.md index d7577ae96195f2..96df65be01ebe2 100644 --- a/Symbolic-Links.md +++ b/Symbolic-Links.md @@ -32,9 +32,9 @@ mklink this-link-points-to c:\that-file The privilege of `Create symbolic links` can be assigned using local policy editors (or via policies from Active Directory in case of domain accounts). Home Editions of Windows do not have these policy editors, but the freely available [Polsedit](http://www.southsoftware.com) can be used on these editions. -- Local Group Policy Editor: Launch `gpedit.msc`, navigate to `Computer configuration - Windows Setting - Security Settings - Local Policies - User Rights Assignment` and add the account(s) to the list named `Create symbolic links`. +- Local Group Policy Editor: Launch `gpedit.msc`, navigate to `Computer Configuration - Windows Settings - Security Settings - Local Policies - User Rights Assignment` and add the account(s) to the list named `Create symbolic links`. -- Local Security Policy: Launch `secpol.msc`, navigate to `Security Settings - Local Policies - User Rights Assignment` and add the account(s) to the list named `Create symbolic links`. +- Local Security Policy: Launch `secpol.msc`, navigate to `Local Policies - User Rights Assignment` and add the account(s) to the list named `Create symbolic links`. - Polsedit: Launch `polseditx32.exe` or `polseditx64.exe` (depending on your Windows version), navigate to `Security Settings - User Rights Assignment` and add the account(s) to the list named `Create symbolic links`. From 10054d2a5d8881dfc37516b8813fec359d83d0e0 Mon Sep 17 00:00:00 2001 From: Sebastian Schuberth Date: Fri, 13 Jul 2018 12:47:47 +0200 Subject: [PATCH 314/591] Add a link on how to enable Developer Mode. --- Symbolic-Links.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Symbolic-Links.md b/Symbolic-Links.md index 96df65be01ebe2..2aa2b1e286ffa0 100644 --- a/Symbolic-Links.md +++ b/Symbolic-Links.md @@ -38,6 +38,6 @@ The privilege of `Create symbolic links` can be assigned using local policy edit - Polsedit: Launch `polseditx32.exe` or `polseditx64.exe` (depending on your Windows version), navigate to `Security Settings - User Rights Assignment` and add the account(s) to the list named `Create symbolic links`. -Note that regardless of privilege assignment, members of the Administrators group will also require UAC elevation (see the full details in the *Access Token Changes* section in this [document on UAC](https://msdn.microsoft.com/en-us/library/bb530410.aspx)). Since Windows 10 version 1703 (*Creators Update*), enabling Developer Mode will disable this restriction and allow creating symlinks without UAC elevation[1] (although Git for Windows still requires UAC elevation up to and including v2.13.0). +Note that regardless of privilege assignment, members of the Administrators group will also require UAC elevation (see the full details in the *Access Token Changes* section in this [document on UAC](https://msdn.microsoft.com/en-us/library/bb530410.aspx)). Since Windows 10 version 1703 (*Creators Update*), [enabling Developer Mode](https://docs.microsoft.com/en-us/windows/uwp/get-started/enable-your-device-for-development) will disable this restriction and allow creating symlinks without UAC elevation[1] (although Git for Windows still requires UAC elevation up to and including v2.13.0). [1] https://blogs.windows.com/buildingapps/2016/12/02/symlinks-windows-10/ \ No newline at end of file From e450ad836fc5a29c1a40ac0b8d6b345c1f5da7dd Mon Sep 17 00:00:00 2001 From: Sebastian Schuberth Date: Fri, 13 Jul 2018 12:48:49 +0200 Subject: [PATCH 315/591] Inline the link to "symlinks without UAC elevation". --- Symbolic-Links.md | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/Symbolic-Links.md b/Symbolic-Links.md index 2aa2b1e286ffa0..80d7c13b78805d 100644 --- a/Symbolic-Links.md +++ b/Symbolic-Links.md @@ -38,6 +38,4 @@ The privilege of `Create symbolic links` can be assigned using local policy edit - Polsedit: Launch `polseditx32.exe` or `polseditx64.exe` (depending on your Windows version), navigate to `Security Settings - User Rights Assignment` and add the account(s) to the list named `Create symbolic links`. -Note that regardless of privilege assignment, members of the Administrators group will also require UAC elevation (see the full details in the *Access Token Changes* section in this [document on UAC](https://msdn.microsoft.com/en-us/library/bb530410.aspx)). Since Windows 10 version 1703 (*Creators Update*), [enabling Developer Mode](https://docs.microsoft.com/en-us/windows/uwp/get-started/enable-your-device-for-development) will disable this restriction and allow creating symlinks without UAC elevation[1] (although Git for Windows still requires UAC elevation up to and including v2.13.0). - -[1] https://blogs.windows.com/buildingapps/2016/12/02/symlinks-windows-10/ \ No newline at end of file +Note that regardless of privilege assignment, members of the Administrators group will also require UAC elevation (see the full details in the *Access Token Changes* section in this [document on UAC](https://msdn.microsoft.com/en-us/library/bb530410.aspx)). Since Windows 10 version 1703 (*Creators Update*), [enabling Developer Mode](https://docs.microsoft.com/en-us/windows/uwp/get-started/enable-your-device-for-development) will disable this restriction and [allow creating symlinks without UAC elevation](https://blogs.windows.com/buildingapps/2016/12/02/symlinks-windows-10/) (although Git for Windows still requires UAC elevation up to and including v2.13.0). \ No newline at end of file From 55788df11eaa0351c6d94a465fbdfa9fb8758a01 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Thu, 19 Jul 2018 18:28:59 +0200 Subject: [PATCH 316/591] Outline how to address problems when `msys-2.0.dll`'s base address is already problematic --- 32-bit-issues.md | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/32-bit-issues.md b/32-bit-issues.md index ab5d958414e60d..6733b962d259bc 100644 --- a/32-bit-issues.md +++ b/32-bit-issues.md @@ -58,3 +58,14 @@ If you still insist on fixing it manually, please understand that this is *not* ```cmd usr\bin\dash -c '/usr/bin/dash /usr/bin/rebaseall -p' ``` + +In the case that the MSYS2 runtime needs to be rebased, too, you will need to call something like this: + +```cmd +copy usr\bin\msys-2.0.dll copy-msys-2.0.dll +usr\bin\rebase.exe -b 0x67000000 copy-msys-2.0.dll +copy copy-msys-2.0.dll usr\bin\msys-2.0.dll +usr\bin\dash.exe -c 'cd / && /usr/bin/dash.exe /usr/bin/rebaseall' +``` + +These commands need to be executed in the top-level directory, and the address (0x67000000) might need to be adjusted. \ No newline at end of file From 311465371591e60e08844a4bbe78e83d27f92990 Mon Sep 17 00:00:00 2001 From: isoard xavier Date: Sun, 22 Jul 2018 16:11:01 +0200 Subject: [PATCH 317/591] Updated Contact (markdown) From 65df5804119bf45473b32218d83ec97967a61ccd Mon Sep 17 00:00:00 2001 From: fabin1 <42096556+fabin1@users.noreply.github.com> Date: Sun, 12 Aug 2018 19:10:32 +0200 Subject: [PATCH 318/591] Updated FAQ (markdown) From 8b4e9e3f09d6b50a93e67ea4376688ee7b3d91ff Mon Sep 17 00:00:00 2001 From: mehrdadn Date: Mon, 3 Sep 2018 00:38:19 -0700 Subject: [PATCH 319/591] Updated Install inside MSYS2 proper (markdown) --- Install-inside-MSYS2-proper.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index bed9a152f7c581..476cd5c34125d0 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -27,7 +27,7 @@ and optionally also the MINGW-only repository for the *opposite* architecture (i pacboy update - 5. This updates `msys2-runtime` and therefore will ask you to close the window (*not* just exit the pacman process). Don't panic, simply close all currently open MSYS2 shells and MSYS2 programs. Once all are closed, start a new terminal again. + 5. This updates `msys2-runtime` and therefore will ask you to close the window (*not* just exit the pacman process). Don't panic, simply close all currently open MSYS2 shells and MSYS2 programs. Double-check Task Manager and kill `pacman.exe` it's still running after the window is closed, because it can linger. Once all are closed, start a new terminal again. 6. Then synchronize *again* (updating the non-core part of the packages): From 9cc3d6db946da98cec64fc19dff72af0462f39e3 Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Sun, 9 Sep 2018 14:10:44 +0100 Subject: [PATCH 320/591] This is an initial holding page to allow others to improve this 'What I know Is' page --- ...uotation,-Executable-bit-and-file-modes.md | 29 +++++++++++++++++++ 1 file changed, 29 insertions(+) create mode 100644 File-names,-Branch-names,-Path-quotation,-Executable-bit-and-file-modes.md diff --git a/File-names,-Branch-names,-Path-quotation,-Executable-bit-and-file-modes.md b/File-names,-Branch-names,-Path-quotation,-Executable-bit-and-file-modes.md new file mode 100644 index 00000000000000..73a23fca9bd10e --- /dev/null +++ b/File-names,-Branch-names,-Path-quotation,-Executable-bit-and-file-modes.md @@ -0,0 +1,29 @@ +# Case Preservation, Case insensitivity + +Windows is case insensitive, but case preserving for filenames. Meanwhile Linux/Posix, for which Git is designed, is case sensitive. + +In addition Git branch names are stored as filenames. + +This means that in normal usage, Git will have difficulty when it meets a changed case file or branch. Lower case is common for Linux usage! + +E.g. `Master` branch and `master` branch are different, even though, on Windows, Git will often mistake one for the other (because Windows will read the 'other' case version of the file. + +Likewise Windows will not be able to check out both an upper case and lower case version of a file(s). Apparently the vim repository has this 'two versions' Vim/vim problem. + +Windows alsao cannot checkout files which contain special characters, such as colon(:) etc. This can cause cross system management issues. + +# Path Quotation + +Spaces in filenames is common in Windows, but rare in Linux. Linux has, like Windows, multiple path quoting mechanisms. In addition Linux can accept any character in any filename, including 'special' characters. This means that the path conversion between Windows and Git is imperfect and dependant on the particular command structure and 'terminal' in use. + +Many Git commands do not report errors in the way that maybe expected by Windows users - some will simply ignore invalid options and paths, leaving the unfamiliar user wondering what happened. The `git config` is one area where this may happen, especially as there can be quoting confusion (single, double, or none) between bash, cmd, and powershell. (e.g. see [thread](https://public-inbox.org/git/d9330ba54fbda54a92a9f4d9320836d88ce9a6e6.camel@mad-scientist.net/)) + +# Executable and Mode Bits + +Linux attaches a mode word to each file, with bits that indicate if the file is executable, readable, writable, and other ownership aspects (`chmod`). This does not map well to Windows semantics, especially for the executable bit. The existing mode bits are retained in the repository tree meta data, which is then held locally in the index. + +Users may need to directly manipulate the mode bits where necessary - the [stackoverflow page](https://stackoverflow.com/a/38285462/717355) shows how to use the `--chmod` option while adding or updating files. + + + + From 611e61253e9f5ad58460887759d02c3935f5ec63 Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Sun, 9 Sep 2018 14:56:19 +0100 Subject: [PATCH 321/591] Added core.FileMode note --- ...tion,-Executable-bit-and-file-modes,-core.FileMode.md | 9 +++++++++ 1 file changed, 9 insertions(+) rename File-names,-Branch-names,-Path-quotation,-Executable-bit-and-file-modes.md => File-names,-Branch-names,-Path-quotation,-Executable-bit-and-file-modes,-core.FileMode.md (73%) diff --git a/File-names,-Branch-names,-Path-quotation,-Executable-bit-and-file-modes.md b/File-names,-Branch-names,-Path-quotation,-Executable-bit-and-file-modes,-core.FileMode.md similarity index 73% rename from File-names,-Branch-names,-Path-quotation,-Executable-bit-and-file-modes.md rename to File-names,-Branch-names,-Path-quotation,-Executable-bit-and-file-modes,-core.FileMode.md index 73a23fca9bd10e..3c6fe251deec07 100644 --- a/File-names,-Branch-names,-Path-quotation,-Executable-bit-and-file-modes.md +++ b/File-names,-Branch-names,-Path-quotation,-Executable-bit-and-file-modes,-core.FileMode.md @@ -24,6 +24,15 @@ Linux attaches a mode word to each file, with bits that indicate if the file is Users may need to directly manipulate the mode bits where necessary - the [stackoverflow page](https://stackoverflow.com/a/38285462/717355) shows how to use the `--chmod` option while adding or updating files. +# core.FileMode + +The core.FileMode configuration records, for the locally cloned repository, the local file system semantics (i.e. is it case sensitive / case preserving or not). DO NOT change this, unless it is actually set wrong. Git will trust this setting and miss-setting it may cause unexpected effects and damage - Don't do it, the internet, as ever, is probably wrong. + +From https://git-scm.com/docs/git-config#git-config-corefileMode +> Tells Git if the executable bit of files in the working tree is to be honored. + +> Some filesystems lose the executable bit when a file that is marked as executable is checked out, or checks out a non-executable file with executable bit on. git-clone[1] or git-init[1] probe the filesystem to see if it handles the executable bit correctly and this variable is automatically set as necessary. + From 7d745941caf7a6b8bb80f994b2522154a8b50aa7 Mon Sep 17 00:00:00 2001 From: sebastian1000 <43155814+sebastian1000@users.noreply.github.com> Date: Thu, 13 Sep 2018 15:45:34 -0300 Subject: [PATCH 322/591] Created mi primer ejercicio HTML (markdown) --- mi-primer-ejercicio-HTML.md | 8 ++++++++ 1 file changed, 8 insertions(+) create mode 100644 mi-primer-ejercicio-HTML.md diff --git a/mi-primer-ejercicio-HTML.md b/mi-primer-ejercicio-HTML.md new file mode 100644 index 00000000000000..d1028bfb13f10b --- /dev/null +++ b/mi-primer-ejercicio-HTML.md @@ -0,0 +1,8 @@ + + + + + + + Este es mi primer HTML de=sanchez sebastian + \ No newline at end of file From f786ee5dbee3d86199070a1e40f38de12b35abc4 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Thu, 13 Sep 2018 14:31:01 -0500 Subject: [PATCH 323/591] Destroyed mi primer ejercicio HTML (markdown) --- mi-primer-ejercicio-HTML.md | 8 -------- 1 file changed, 8 deletions(-) delete mode 100644 mi-primer-ejercicio-HTML.md diff --git a/mi-primer-ejercicio-HTML.md b/mi-primer-ejercicio-HTML.md deleted file mode 100644 index d1028bfb13f10b..00000000000000 --- a/mi-primer-ejercicio-HTML.md +++ /dev/null @@ -1,8 +0,0 @@ - - - - - - - Este es mi primer HTML de=sanchez sebastian - \ No newline at end of file From 3a442adc664593fb4e984a83dcee9f87530c4d4a Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Mon, 8 Oct 2018 23:13:55 +0100 Subject: [PATCH 324/591] make release notes look like a web link --- FAQ.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/FAQ.md b/FAQ.md index 48dd3fb7a939f0..c4b2a6ca90e935 100644 --- a/FAQ.md +++ b/FAQ.md @@ -54,7 +54,7 @@ For advanced users working with the *Git for Windows* SDK `pacman` is available For hashes see https://github.com/git-for-windows/git/releases -For (G4W) release notes see the [build-extra repo](https://github.com/git-for-windows/build-extra/blob/master/ReleaseNotes.md), or the top level of your installation (e.g. C:\Program Files\Git\ReleaseNotes.html). +For (G4W) release notes see the [build-extra repo](https://github.com/git-for-windows/build-extra/blob/master/ReleaseNotes.md), or the top level of your installation (e.g. [C:\Program Files\Git\ReleaseNotes.html](http://www.example.com/Program%20Files/Git/ReleaseNotes.html) - via manual browsing). For extracting 7z/zip archives see [page](https://github.com/git-for-windows/git/wiki/Zip-Archives---extracting-the-released-archives). From 2327340d4366e27502d0bdf27afd013f26aac933 Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Thu, 11 Oct 2018 23:58:39 +0100 Subject: [PATCH 325/591] I'm that poor soul.. --- 0.-Index.md | 42 ++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 42 insertions(+) create mode 100644 0.-Index.md diff --git a/0.-Index.md b/0.-Index.md new file mode 100644 index 00000000000000..98365857d3a7e2 --- /dev/null +++ b/0.-Index.md @@ -0,0 +1,42 @@ +This is for the poor souls in corporate IE environments who can't expand the page list. + +* [Home](https://github.com/git-for-windows/git/wiki) +* [32 bit issues](https://github.com/git-for-windows/git/wiki/32-bit-issues) +* [Adding regression tests](https://github.com/git-for-windows/git/wiki/Adding-regression-tests) +* [Auto launching ssh agent when git starts](https://github.com/git-for-windows/git/wiki/Auto-launching-ssh-agent-when-git-starts) +* [Building Git](https://github.com/git-for-windows/git/wiki/Building-Git) +* [Building msys2 runtime](https://github.com/git-for-windows/git/wiki/Building-msys2-runtime) +* [Compiling Git with Visual Studio](https://github.com/git-for-windows/git/wiki/Compiling-Git-with-Visual-Studio) +* [Contact](https://github.com/git-for-windows/git/wiki/Contact) +* [Continuous Integration (CI)](https://github.com/git-for-windows/git/wiki/Continuous-Integration-(CI)) +* [Debugging Git](https://github.com/git-for-windows/git/wiki/Debugging-Git) +* [Diagnosing performance issues](https://github.com/git-for-windows/git/wiki/Diagnosing-performance-issues) +* [FAQ](https://github.com/git-for-windows/git/wiki/FAQ) +* [File names, Branch names, Path quotation, Executable bit and file modes, core.FileMode](https://github.com/git-for-windows/git/wiki/File-names,-Branch-names,-Path-quotation,-Executable-bit-and-file-modes,-core.FileMode) +* [fork(), exec(), CreateProcess(): Windows vs Linux](https://github.com/git-for-windows/git/wiki/fork(),-exec(),-CreateProcess():-Windows-vs-Linux) +* [Git cannot create a file or directory with a long path](https://github.com/git-for-windows/git/wiki/Git-cannot-create-a-file-or-directory-with-a-long-path) +* [Good commits](https://github.com/git-for-windows/git/wiki/Good-commits) +* [How to participate](https://github.com/git-for-windows/git/wiki/How-to-participate) +* [Install inside MSYS2 proper](https://github.com/git-for-windows/git/wiki/Install-inside-MSYS2-proper) +* [Issue reporting guidelines](https://github.com/git-for-windows/git/wiki/Issue-reporting-guidelines) +* [Making a portable Git](https://github.com/git-for-windows/git/wiki/Making-a-portable-Git) +* [Making an installer](https://github.com/git-for-windows/git/wiki/Making-an-installer) +* [MinGit is Git for Windows Applications](https://github.com/git-for-windows/git/wiki/MinGit) +* [MSYS2 Notes](https://github.com/git-for-windows/git/wiki/MSYS2-Notes) +* [OpenSSH Integration with Pageant](https://github.com/git-for-windows/git/wiki/OpenSSH-Integration-with-Pageant) +* [Package management](https://github.com/git-for-windows/git/wiki/Package-management) +* [Performance profiling with Visual Studio](https://github.com/git-for-windows/git/wiki/Performance-profiling-with-Visual-Studio) +* [Rebasing Git for Windows](https://github.com/git-for-windows/git/wiki/Rebasing-Git-for-Windows) +* [Release Hashes](https://github.com/git-for-windows/git/wiki/Release-Hashes) +* [Running Git's regression tests](https://github.com/git-for-windows/git/wiki/Running-Git's-regression-tests) +* [Setting your Core.Editor ( e.g. Notepad )](https://github.com/git-for-windows/git/wiki/Setting-your-Core.Editor-(-e.g.-Notepad-)) +* [Silent or Unattended Installation](https://github.com/git-for-windows/git/wiki/Silent-or-Unattended-Installation) +* [Symbolic Links](https://github.com/git-for-windows/git/wiki/Symbolic-Links) +* [The difference between MINGW and MSYS2](https://github.com/git-for-windows/git/wiki/The-difference-between-MINGW-and-MSYS2) +* [Updating your SDK](https://github.com/git-for-windows/git/wiki/Updating-your-SDK) +* [Using sshd to host a git server](https://github.com/git-for-windows/git/wiki/Using-sshd-to-host-a-git-server) +* [Vagrant](https://github.com/git-for-windows/git/wiki/Vagrant) +* [Visual Studio and MSVC compilation](https://github.com/git-for-windows/git/wiki/Visual-Studio-and-MSVC-compilation) +* [Zip Archives extracting the released archives](https://github.com/git-for-windows/git/wiki/Zip-Archives---extracting-the-released-archives) + +-Fin- From 8ffd3fe554c445e72b36c34cc1dd6c8e3f7a3ca0 Mon Sep 17 00:00:00 2001 From: Rob Richardson Date: Tue, 6 Nov 2018 17:40:39 -0700 Subject: [PATCH 326/591] alsao spell correactly --- ...h-quotation,-Executable-bit-and-file-modes,-core.FileMode.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/File-names,-Branch-names,-Path-quotation,-Executable-bit-and-file-modes,-core.FileMode.md b/File-names,-Branch-names,-Path-quotation,-Executable-bit-and-file-modes,-core.FileMode.md index 3c6fe251deec07..f4aedb8b593068 100644 --- a/File-names,-Branch-names,-Path-quotation,-Executable-bit-and-file-modes,-core.FileMode.md +++ b/File-names,-Branch-names,-Path-quotation,-Executable-bit-and-file-modes,-core.FileMode.md @@ -10,7 +10,7 @@ E.g. `Master` branch and `master` branch are different, even though, on Windows, Likewise Windows will not be able to check out both an upper case and lower case version of a file(s). Apparently the vim repository has this 'two versions' Vim/vim problem. -Windows alsao cannot checkout files which contain special characters, such as colon(:) etc. This can cause cross system management issues. +Windows also cannot checkout files which contain special characters, such as colon(:) etc. This can cause cross system management issues. # Path Quotation From d0abacd2b1cedaf480d1d687ac0097340230b180 Mon Sep 17 00:00:00 2001 From: Pastisa <43981671+Pastisa@users.noreply.github.com> Date: Thu, 8 Nov 2018 01:00:50 +0700 Subject: [PATCH 327/591] https://github.com/git-for-windows/git.wiki.git --- https:--github.com-git-for-windows-git.wiki.git.org | 1 + 1 file changed, 1 insertion(+) create mode 100644 https:--github.com-git-for-windows-git.wiki.git.org diff --git a/https:--github.com-git-for-windows-git.wiki.git.org b/https:--github.com-git-for-windows-git.wiki.git.org new file mode 100644 index 00000000000000..579abf2fb04c70 --- /dev/null +++ b/https:--github.com-git-for-windows-git.wiki.git.org @@ -0,0 +1 @@ +https://github.com/git-for-windows/git.wiki.git \ No newline at end of file From d1ff88e489449162c0100953c970f8b4124c9803 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Thu, 8 Nov 2018 13:02:05 +0100 Subject: [PATCH 328/591] Delete bogus file Signed-off-by: Johannes Schindelin --- https:--github.com-git-for-windows-git.wiki.git.org | 1 - 1 file changed, 1 deletion(-) delete mode 100644 https:--github.com-git-for-windows-git.wiki.git.org diff --git a/https:--github.com-git-for-windows-git.wiki.git.org b/https:--github.com-git-for-windows-git.wiki.git.org deleted file mode 100644 index 579abf2fb04c70..00000000000000 --- a/https:--github.com-git-for-windows-git.wiki.git.org +++ /dev/null @@ -1 +0,0 @@ -https://github.com/git-for-windows/git.wiki.git \ No newline at end of file From 995d43ace878a63b34b2c5c400a2858fd83a4f76 Mon Sep 17 00:00:00 2001 From: Tao Klerks Date: Tue, 13 Nov 2018 12:12:54 +0100 Subject: [PATCH 329/591] Add notes about cross-environment path option, and correct paragraph about msys2 tmp path mapping. A default msys2 insdtall currently seems to use a shared "c:\msys64\tmp" path... --- OpenSSH-Integration-with-Pageant.md | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/OpenSSH-Integration-with-Pageant.md b/OpenSSH-Integration-with-Pageant.md index 06fbb63e50ab9f..21822b8122eaa0 100644 --- a/OpenSSH-Integration-with-Pageant.md +++ b/OpenSSH-Integration-with-Pageant.md @@ -38,7 +38,7 @@ If you use Git from Git CMD, or directly from the Windows command prompt, then y Unlike the Git Bash case above, this scenario **requires** the _SSH\_AUTH\_SOCK_ environment variable to be set before running the script... otherwise it will simply exit without performing any action. This is normally configured as a persistent **USER** variable, with the value specifying the desired socket file path in Unix/MSYS2 format. -NOTE: Since there can only be a single global variable of a given name, this approach may or may not cause conflicts if you have multiple environments which utilize the SSH_AUTH_SOCK setting. Running Git alongside of Cygwin, for example. +NOTE: Since there can only be a single global variable of a given name, this approach may or may not cause conflicts if you have multiple environments which utilize the SSH_AUTH_SOCK setting. Running Git alongside of Cygwin, or MSYS2, for example. One way to address this is to use a fully-qualified Windows path for the socket instead of an environment-specific Unix/MSYS2 path. #### Windows 7 @@ -49,6 +49,8 @@ Now launch a new Git CMD or Windows command prompt (pre-existing sessions won't C:\Users\heinz.doofenshmirtz> set SSH_AUTH_SOCK SSH_AUTH_SOCK=/tmp/.ssh-pageant-heinz.doofenshmirtz +NOTE: the cross-environment-compatible (git for windows, msys2, and cygwin) equivalent would require a fully qualified windows path like `C:\Users\MYUSERNAME\AppData\Local\Temp\.ssh-pageant-MYUSERNAME`. The correct value can be determined by running a command like `cygpath --windows /tmp/.ssh-pageant-%USERNAME%` in a Git Bash window. + ### Launch ssh\-pageant At this point you should run _start\-ssh\-pageant.cmd_ manually, in order to verify that the agent starts successfully. Assuming that Git is installed into _C:\Program Files\Git_, this should look something like: @@ -75,4 +77,4 @@ The most common approach is to create a shortcut pointing to _start\-ssh\-pagean ## Security Considerations -Since _ssh\-pageant_ (like _ssh\-agent_) is intended to bypass the requirement to repeatedly enter your private key password, it's imperative that its socket file be private in order to use it safely. In other words, you want to be **extremely** careful on multi-user systems to ensure that the **SSH_AUTH_SOCK** file -- and preferably the directory which includes it -- isn't accessible to anyone else. For a normal MSYS2 configuration (which includes Git) this shouldn't be an issue, as _/tmp_ is normally mapped to a private location under your Windows user profile. \ No newline at end of file +Since _ssh\-pageant_ (like _ssh\-agent_) is intended to bypass the requirement to repeatedly enter your private key password, it's imperative that its socket file be private in order to use it safely. In other words, you want to be **extremely** careful on multi-user systems to ensure that the **SSH_AUTH_SOCK** file -- and preferably the directory which includes it -- isn't accessible to anyone else. For a normal Git for Windows configuration this shouldn't be an issue, as _/tmp_ is normally mapped to a private location under your Windows user profile. \ No newline at end of file From 36d61869cd0bd609bff9e3d24d94a09e50dc8aa9 Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Tue, 13 Nov 2018 15:04:41 +0000 Subject: [PATCH 330/591] List the Snapshot build location --- FAQ.md | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/FAQ.md b/FAQ.md index c4b2a6ca90e935..84d1b6795755ad 100644 --- a/FAQ.md +++ b/FAQ.md @@ -58,6 +58,11 @@ For (G4W) release notes see the [build-extra repo](https://github.com/git-for-wi For extracting 7z/zip archives see [page](https://github.com/git-for-windows/git/wiki/Zip-Archives---extracting-the-released-archives). +## Are there 'Nightly' builds of the latest and greatest + +The Git for Windows builds are not quite that frequent, but there are Snapshot builds listed at https://wingit.blob.core.windows.net/files/index.html + +These often 'fix' (or attempt fixes) recent issues before a new formal release. Check their commit notes and links to issues to see if your problem is included. ## Some native console programs don't work when run from Git Bash. How to fix it? From aabba33f4c99c8d8be3b99a66e86fd13e938ebd0 Mon Sep 17 00:00:00 2001 From: avinashgowdac56 <33690864+avinashgowdac56@users.noreply.github.com> Date: Fri, 23 Nov 2018 21:58:49 +0530 Subject: [PATCH 331/591] Updated _Footer (markdown) --- _Footer.md | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/_Footer.md b/_Footer.md index e206dc2d0d37d3..75a826664a7922 100644 --- a/_Footer.md +++ b/_Footer.md @@ -1 +1,3 @@ -This is the _Git for Windows_ wiki. See [how to participate](https://github.com/git-for-windows/git/wiki/How-to-participate). \ No newline at end of file +# ## ### ## # *This is the _Git for Windows_ wiki. See [how to participate](https://github.com/git-for-windows/git/wiki/How-to-participate). + + From e99b2c88da760994f9764607f557d9f98701b8f1 Mon Sep 17 00:00:00 2001 From: avinashgowdac56 <33690864+avinashgowdac56@users.noreply.github.com> Date: Fri, 23 Nov 2018 22:04:09 +0530 Subject: [PATCH 332/591] Updated _Footer (markdown) --- _Footer.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/_Footer.md b/_Footer.md index 75a826664a7922..24155c6531ad1b 100644 --- a/_Footer.md +++ b/_Footer.md @@ -1,3 +1,3 @@ -# ## ### ## # *This is the _Git for Windows_ wiki. See [how to participate](https://github.com/git-for-windows/git/wiki/How-to-participate). +# > # ## ### ## # *This is the _Git for Windows_ wiki. See [how to participate](https://github.com/git-for-windows/git/wiki/How-to-participate). From 8c3c2a1682a3c0b92af2597039bc8c4b28d968cc Mon Sep 17 00:00:00 2001 From: avinashgowdac56 <33690864+avinashgowdac56@users.noreply.github.com> Date: Fri, 23 Nov 2018 22:05:21 +0530 Subject: [PATCH 333/591] Updated _Footer (markdown) --- _Footer.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/_Footer.md b/_Footer.md index 24155c6531ad1b..81ec4b8dfee837 100644 --- a/_Footer.md +++ b/_Footer.md @@ -1,3 +1,3 @@ -# > # ## ### ## # *This is the _Git for Windows_ wiki. See [how to participate](https://github.com/git-for-windows/git/wiki/How-to-participate). +[how-to-participate](https://gitforwindows.org/governance-model.html)# > # ## ### ## # *This is the _Git for Windows_ wiki. See [how to participate](https://github.com/git-for-windows/git/wiki/How-to-participate). From 7df73201e537c9674d36a9aa5f586ce79a900474 Mon Sep 17 00:00:00 2001 From: avinashgowdac56 <33690864+avinashgowdac56@users.noreply.github.com> Date: Fri, 23 Nov 2018 22:06:50 +0530 Subject: [PATCH 334/591] Updated _Footer (markdown) --- _Footer.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/_Footer.md b/_Footer.md index 81ec4b8dfee837..b2de00ef70379f 100644 --- a/_Footer.md +++ b/_Footer.md @@ -1,3 +1,3 @@ -[how-to-participate](https://gitforwindows.org/governance-model.html)# > # ## ### ## # *This is the _Git for Windows_ wiki. See [how to participate](https://github.com/git-for-windows/git/wiki/How-to-participate). +(https://gitforwindows.org/governance-model.html)# > # ## ### ## # *This is the _Git for Windows_ wiki. See [how to participate](https://github.com/git-for-windows/git/wiki/[how-to-participate]). From 3fbcdab74b464dddaff9ddb51ea1035a005da202 Mon Sep 17 00:00:00 2001 From: avinashgowdac56 <33690864+avinashgowdac56@users.noreply.github.com> Date: Fri, 23 Nov 2018 22:08:21 +0530 Subject: [PATCH 335/591] Updated _Footer (markdown) --- _Footer.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/_Footer.md b/_Footer.md index b2de00ef70379f..0b6746c93dd670 100644 --- a/_Footer.md +++ b/_Footer.md @@ -1,3 +1,3 @@ -(https://gitforwindows.org/governance-model.html)# > # ## ### ## # *This is the _Git for Windows_ wiki. See [how to participate](https://github.com/git-for-windows/git/wiki/[how-to-participate]). +# > # ## ### ## # *This is the _Git for Windows_ wiki. See [how to participate]. From c5fb2eb06597215d6b87638c7d4b7de2fdca25d6 Mon Sep 17 00:00:00 2001 From: avinashgowdac56 <33690864+avinashgowdac56@users.noreply.github.com> Date: Fri, 23 Nov 2018 22:09:54 +0530 Subject: [PATCH 336/591] Updated _Footer (markdown) --- _Footer.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/_Footer.md b/_Footer.md index 0b6746c93dd670..bb323b84076678 100644 --- a/_Footer.md +++ b/_Footer.md @@ -1,3 +1,3 @@ -# > # ## ### ## # *This is the _Git for Windows_ wiki. See [how to participate]. +# > # ## ### ## # *This is the _Git for Windows_ wiki. See [how-to-participate](https://gitforwindows.org/governance-model.html)# . From b80407adef4f7df1170ff06fbdc78b24d37985a2 Mon Sep 17 00:00:00 2001 From: avinashgowdac56 <33690864+avinashgowdac56@users.noreply.github.com> Date: Fri, 23 Nov 2018 22:11:13 +0530 Subject: [PATCH 337/591] Updated _Footer (markdown => mediawiki) --- _Footer.md => _Footer.mediawiki | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) rename _Footer.md => _Footer.mediawiki (97%) diff --git a/_Footer.md b/_Footer.mediawiki similarity index 97% rename from _Footer.md rename to _Footer.mediawiki index bb323b84076678..65a62f83f0e8b2 100644 --- a/_Footer.md +++ b/_Footer.mediawiki @@ -1,3 +1,3 @@ -# > # ## ### ## # *This is the _Git for Windows_ wiki. See [how-to-participate](https://gitforwindows.org/governance-model.html)# . +# > # ## ### ## # *This is the _Git for Windows_ wiki. See [how-to-participate](https://gitforwindows.org/governance-model.html). From 8aef66e1c7d5e674e1b6cc2212529a94c6ccd7b5 Mon Sep 17 00:00:00 2001 From: avinashgowdac56 <33690864+avinashgowdac56@users.noreply.github.com> Date: Fri, 23 Nov 2018 22:11:44 +0530 Subject: [PATCH 338/591] Updated _Footer (mediawiki => asciidoc) --- _Footer.mediawiki => _Footer.asciidoc | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename _Footer.mediawiki => _Footer.asciidoc (100%) diff --git a/_Footer.mediawiki b/_Footer.asciidoc similarity index 100% rename from _Footer.mediawiki rename to _Footer.asciidoc From 29e62835bc966d5786269fc4c819b61315f2c43b Mon Sep 17 00:00:00 2001 From: avinashgowdac56 <33690864+avinashgowdac56@users.noreply.github.com> Date: Fri, 23 Nov 2018 22:12:05 +0530 Subject: [PATCH 339/591] Updated _Footer (asciidoc => markdown) --- _Footer.asciidoc => _Footer.md | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename _Footer.asciidoc => _Footer.md (100%) diff --git a/_Footer.asciidoc b/_Footer.md similarity index 100% rename from _Footer.asciidoc rename to _Footer.md From 7b64d397e4822792d39d6117a3f21e3e20df0f48 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Wed, 9 Jan 2019 15:09:51 +0100 Subject: [PATCH 340/591] Mention `updpkgsums` --- Package-management.md | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/Package-management.md b/Package-management.md index 80f90013aae536..fe4714247b0bab 100644 --- a/Package-management.md +++ b/Package-management.md @@ -78,10 +78,12 @@ makepkg-mingw -s To build MSys packages, you need to start the `MSys` shell (e.g. `C:\git-sdk-64\msys2_shell.cmd -msys`, which sets `MSYSTEM=MSYS` before running the Bash), clone the [`MSYS2-packages`](https://github.com/git-for-windows/MSYS2-packages) repository (recommended location: `/usr/src/MSYS2-packages`), `cd` to the appropriate subdirectory and call -```bas +```bash makepkg -s ``` +If you have modified any files (like `PKGBUILD`) you need to update the checksums using the `updpkgsums` command before running `makepkg` or `makepkg-mingw`. + *Note*: Before building the first MSys package, as per [MSYS2's own documentation](http://sourceforge.net/p/msys2/wiki/Contributing%20to%20MSYS2/) you need to install the development packages for development: ```sh From a9a42c35e8889f047a20c242590a47394bb37a8c Mon Sep 17 00:00:00 2001 From: lwtlp987 <47211054+lwtlp987@users.noreply.github.com> Date: Mon, 11 Feb 2019 22:25:22 +0000 Subject: [PATCH 341/591] Destroyed FAQ (markdown) --- FAQ.md | 118 --------------------------------------------------------- 1 file changed, 118 deletions(-) delete mode 100644 FAQ.md diff --git a/FAQ.md b/FAQ.md deleted file mode 100644 index 84d1b6795755ad..00000000000000 --- a/FAQ.md +++ /dev/null @@ -1,118 +0,0 @@ -## Which versions of Windows are supported? - -Git for Windows currently works with all recent, commercially released x86 32 bit and 64 bit versions of Windows, starting with Windows Vista. - -*** -NOTE: Git for Windows version [2.10.0](https://github.com/git-for-windows/git/releases/tag/v2.10.0.windows.1) was the last version supporting Windows XP and Server 2003. -*** - -Windows XP and Windows Server 2003 are long past their end of life, hence support for these versions was dropped from Git for Windows 2.10.1 and later. This limitation is inherited by Git's use of MSYS2, which in turn inherited it from [Cygwin](https://cygwin.com/ml/cygwin/2015-08/msg00446.html). - -More information here: [Git for Windows' prerequisites](https://gitforwindows.org/requirements.html). - -## Is there an MSI for installation via Group Policy? - -There is currently no MSI package; there is an exe installer and a portable package. You are welcome to contribute a Pull Request that packages a new installer. - -There is an existing Pull Request in development and looking for testers, please try out https://github.com/robmen/gitsetup/issues/1 and give feedback. - -In the meantime you could try: - - * using the portable package - * deploying the exe installer with System Center Configuration Manager - * deploying the portable package via a script - * deploying the Chocolatey package via Puppet (or something similar) - -## Should I upgrade to a newer Git for Windows version? - -In general, yes: it is a good idea to stay up-to-date. - -If you have a version older than 2.17.1(2), it is *highly* advisable to upgrade. These versions fixed critical bugs, therefore sticking with older Git for Windows versions makes you vulnerable: 2.17.1(2), 2.14.1, 2.7.4, 2.7.0, 2.6.1, 2.5.2, 1.9.5-preview20150319, and 1.9.5-preview20141217. - -## What is the release cadence of Git for Windows? - -Official Git for Windows versions mainly follow Git's release cycle: every 12 weeks or so, a new major Git version is released (see details here: http://tinyurl.com/gitCal). Typically, Git for Windows will follow suit within a day. - -Other than that, Git for Windows follows the *newest* Git version's maintenance releases (read: after Git for Windows v2.15.0 was released, no new Git for Windows v2.14.x version would be released). Indicators for imminent maintenance releases of Git are: - -- The Git maintainer sometimes talks about this in the preamble of the ["What's cooking in git.git" mails](https://public-inbox.org/git/?q=s%3A%22what%27s+cooking%22+AND+f%3Agitster%40pobox.com). -- The [`maint` in git.git](https://github.com/git/git/commits/maint) accumulates critical patches. - -Finally, Git for Windows is sometimes released in "out-of-band" versions, when critical fixes specific to Git for Windows necessitate it. These out-of-band versions are indicated by appending a `(2)` to the latest release (or `(3)`, `(4)`, etc). Examples for such out-of-band versions include: [Git for Windows v2.15.1(2)](https://github.com/git-for-windows/git/releases/tag/v2.15.1.windows.2) and [Git for Windows v2.16.1(4)](https://github.com/git-for-windows/git/releases/tag/v2.16.1.windows.4). - -## What is the relationship between *Git for Windows* and *msysGit*? - -*Git for Windows* used to be developed using the development environment called "msysGit", but roughly coinciding with Git 2.1, msysGit was superseded by a new development environment: the [Git for Windows SDK](https://github.com/git-for-windows/build-extra/releases). See [here](https://github.com/git-for-windows/git/wiki/Updating-your-SDK) to get a copy. - -## How do I update *Git for Windows* upon new releases? - -This depends on how you installed *Git for Windows*. The bundle installation requires you to download and install the new version. Any customizations you made will be kept as long as you did so in the appropriate configuration folders. - -For advanced users working with the *Git for Windows* SDK `pacman` is available as a package manager. See [Package management](Package-management) - -## How do I check the release hash and release notes - -For hashes see https://github.com/git-for-windows/git/releases - -For (G4W) release notes see the [build-extra repo](https://github.com/git-for-windows/build-extra/blob/master/ReleaseNotes.md), or the top level of your installation (e.g. [C:\Program Files\Git\ReleaseNotes.html](http://www.example.com/Program%20Files/Git/ReleaseNotes.html) - via manual browsing). - -For extracting 7z/zip archives see [page](https://github.com/git-for-windows/git/wiki/Zip-Archives---extracting-the-released-archives). - -## Are there 'Nightly' builds of the latest and greatest - -The Git for Windows builds are not quite that frequent, but there are Snapshot builds listed at https://wingit.blob.core.windows.net/files/index.html - -These often 'fix' (or attempt fixes) recent issues before a new formal release. Check their commit notes and links to issues to see if your problem is included. - -## Some native console programs don't work when run from Git Bash. How to fix it? - -*Git for Windows* defaults to using [mintty](https://code.google.com/p/mintty/) terminal. Compared to default Windows console host, it provides normal multi-line cut&paste, working resizing, defaults to unicode font and avoids some bugs in the default console host. However it does not present itself as console to native applications (those *not* built with MSys or Cygwin), so in these applications: - - * Non-ascii output may be corrupted due to mismatch in character sets (MSys and Cygwin use utf-8 while Windows will fall back to the legacy dos codepages in this case). - * Interactive and full-screen applications won't work at all. - -There are several methods for working around these problems: - - * Run programs that have problems using the [`winpty`](https://github.com/rprichard/winpty) utility. This allows you to keep using the nicer mintty terminal, but can become unwieldy if you need the workaround for many programs. - * Modify the shortcut for Git Bash to run `bash` directly without `mintty` so it uses the default console host and configure it for "Quick Edit", reasonable size and scroll-back and suitable unicode font. You'll still have to live with the other quirks of console host. - * Install and use [ConEmu](http://conemu.github.io/). - -## I get errors trying to check out files with long path names. -Windows file paths are by default limited to 255 characters. Some repositories may have committed files which contain paths longer than the limit. By default, *Git for Windows* does not support long paths, and will print errors when trying to perform any operation on a long file name. Set the configuration property `core.longpaths` to true to allow certain Git operations to properly handle these files. See [this wiki page](https://github.com/git-for-windows/git/wiki/Git-cannot-create-a-file-or-directory-with-a-long-path) for more information. - -## Excel file modifications not always noticed. -Excel (and some other apps) do not update the *modified time* of its files which is used by Git to quickly detect changes. Rather Excel used the *change time* field. Git will notice the modifications if a `git status` is performed. See [issue 1000](https://github.com/git-for-windows/git/issues/1000#issuecomment-301611003) if you need more background. - -## How do I access a repository hosted on a Microsoft Team Foundation Server inside a Windows domain? - -The Microsoft Team Foundation Server is capable of hosting git repositories. If the server is a member of a windows domain, and your user account is in that domain, you can use domain authentication to identify yourself to the server, and can thus access git repositories without having to enter any credentials. For this to work, the server has to be configured to use domain authentication, _not_ NTLM authentication. The repository URL can be obtained from the TFS web interface, it may look like http://server.example.com:8080/tfs/TWA/TeamDev/_git/reponame. - -In order to instruct git to use domain authentication, prefix the server name with `:@`, like so: `http://:@server.example.com:8080/tfs/TWA/TeamDev/_git/reponame`. This is a special case of the usual `username:password@server` syntax, where both the `username` and `password` fields are empty. This causes git to look up and use your domain credentials. - -## I get "Permission denied (publickey)." when using git pull - -Some DSA keys are not considered secure anymore by OpenSSH 7. Adding "PubkeyAcceptedKeyTypes ssh-dss" to ~/.ssh/config helps. - -## Switch locale for git-bash launcher (of Git for Windows SDK) - -Some developers want to start git-bash (of Git for Windows SDK) with a different language. -To achieve this in windows following command could be placed inside the launcher: -`C:\Windows\System32\cmd.exe /c "set LANG=en_GB && start C:\git-sdk-64\git-bash.exe && exit"` -replace `en_GB` with your preferred locale. - -## I have errors while building the solution in Visual studio -(i.e. `fatal error C1083: Cannot open include file: 'openssl/ssl.h': No such file or directory`) - -Try to open the console and invoke `git\compat\vcbuild\vcpkg_install.bat`. Make sure that it has completed successfully, then clean and rebuild the solution. - -Ensure also that you are using proper Build Tools (v140). It's going by default in VS 2015. If you are using VS 2017, you need to install them manually. Do not upgrade the project to v141 - it can't be done automatically. - -## Licenses - -Reproduced from [Git for Windows' release notes](https://github.com/git-for-windows/build-extra/blob/master/ReleaseNotes.md#licenses): - -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. - -Git for Windows also contains Embedded CAcert Root Certificates. For more information please go to https://www.cacert.org/policy/RootDistributionLicense.php. - -This package contains software from a number of other projects including Bash, zlib, curl, tcl/tk, perl, MSYS2 and a number of libraries and utilities from the GNU project, licensed under the GNU General Public License. Likewise, it contains Perl which is dual licensed under the GNU General Public License and the Artistic License. From 87bcb85ecfa60bb330f20ccf995894757e2ad418 Mon Sep 17 00:00:00 2001 From: MrGentry <47430508+MrGentry@users.noreply.github.com> Date: Sun, 17 Feb 2019 00:34:08 -0800 Subject: [PATCH 342/591] Just nod if you can hear me. --- FAQ.md | 1 + 1 file changed, 1 insertion(+) create mode 100644 FAQ.md diff --git a/FAQ.md b/FAQ.md new file mode 100644 index 00000000000000..58c5ec65c9b8dd --- /dev/null +++ b/FAQ.md @@ -0,0 +1 @@ +Is there anybody out there? \ No newline at end of file From 7210fb71cd4f7a6b88767c2fbe2432ea5ac953fc Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Thu, 21 Feb 2019 23:21:28 +0000 Subject: [PATCH 343/591] `update-core` script has been retired, see https://github.com/msys2/MSYS2-packages/issues/524 --- Updating-your-SDK.md | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/Updating-your-SDK.md b/Updating-your-SDK.md index 9490c3b68698c1..bfe77316f82dd3 100644 --- a/Updating-your-SDK.md +++ b/Updating-your-SDK.md @@ -34,8 +34,9 @@ therefore refuse to overwrite the files from above-mentioned packages. To keep the development environment up-to-date, developers need to run - update-core - # If core-packages are updated during that call you MUST restart MSYS2 + pacman -Syuu + # If core-packages are updated during that call you MUST restart MSYS2, + # follow instructions and repeat. pacman -Syu from time to time. @@ -43,10 +44,12 @@ from time to time. ### Caution (update-core) Core packages like the `msys2-runtime`, `bash` or `pacman` itself should be updated -via the pacman `update-core` script. Because those core packages are linked to the +via the `pacman -Syuu` command [was X`update-core` script X]. Because those core packages are linked to the `msys2-runtime` (and each other), and updating the runtime "in flight" results most often in heap corruption as far as MSYS2 is concerned. +The old `update-core` script has been retired, see https://github.com/msys2/MSYS2-packages/issues/524 + ## Alternative Method An alternative method is to start `git-cmd.exe` and run `pacman -Sy --needed msys2-runtime` and `pacman -S --needed pacman bash`, because that ensures that no obsolete binary continues to be used after the @@ -61,7 +64,6 @@ update. * ArchLinux articles - [Creating Packages](https://wiki.archlinux.org/index.php/Creating_packages) and [PKGBuild](https://wiki.archlinux.org/index.php/PKGBUILD) * [MSYS2 Introduction & Contributing](http://sourceforge.net/p/msys2/wiki/Contributing%20to%20MSYS2/) * [SDK's setup-git-sdk.bat script](https://github.com/git-for-windows/build-extra/blob/master/sdk-installer/setup-git-sdk.bat) -* [pacman's core-update script](https://github.com/Alexpux/MSYS2-pacman/blob/master/scripts/update-core.sh.in) ## Origin of 'net installer' concept From 1cf8a02eaaa6982df7333782d1c8e1d18f995ad9 Mon Sep 17 00:00:00 2001 From: Kexy Biscuit Date: Fri, 22 Feb 2019 10:13:42 +0800 Subject: [PATCH 344/591] Revert changes to 36d6186. --- FAQ.md | 119 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 118 insertions(+), 1 deletion(-) diff --git a/FAQ.md b/FAQ.md index 58c5ec65c9b8dd..84d1b6795755ad 100644 --- a/FAQ.md +++ b/FAQ.md @@ -1 +1,118 @@ -Is there anybody out there? \ No newline at end of file +## Which versions of Windows are supported? + +Git for Windows currently works with all recent, commercially released x86 32 bit and 64 bit versions of Windows, starting with Windows Vista. + +*** +NOTE: Git for Windows version [2.10.0](https://github.com/git-for-windows/git/releases/tag/v2.10.0.windows.1) was the last version supporting Windows XP and Server 2003. +*** + +Windows XP and Windows Server 2003 are long past their end of life, hence support for these versions was dropped from Git for Windows 2.10.1 and later. This limitation is inherited by Git's use of MSYS2, which in turn inherited it from [Cygwin](https://cygwin.com/ml/cygwin/2015-08/msg00446.html). + +More information here: [Git for Windows' prerequisites](https://gitforwindows.org/requirements.html). + +## Is there an MSI for installation via Group Policy? + +There is currently no MSI package; there is an exe installer and a portable package. You are welcome to contribute a Pull Request that packages a new installer. + +There is an existing Pull Request in development and looking for testers, please try out https://github.com/robmen/gitsetup/issues/1 and give feedback. + +In the meantime you could try: + + * using the portable package + * deploying the exe installer with System Center Configuration Manager + * deploying the portable package via a script + * deploying the Chocolatey package via Puppet (or something similar) + +## Should I upgrade to a newer Git for Windows version? + +In general, yes: it is a good idea to stay up-to-date. + +If you have a version older than 2.17.1(2), it is *highly* advisable to upgrade. These versions fixed critical bugs, therefore sticking with older Git for Windows versions makes you vulnerable: 2.17.1(2), 2.14.1, 2.7.4, 2.7.0, 2.6.1, 2.5.2, 1.9.5-preview20150319, and 1.9.5-preview20141217. + +## What is the release cadence of Git for Windows? + +Official Git for Windows versions mainly follow Git's release cycle: every 12 weeks or so, a new major Git version is released (see details here: http://tinyurl.com/gitCal). Typically, Git for Windows will follow suit within a day. + +Other than that, Git for Windows follows the *newest* Git version's maintenance releases (read: after Git for Windows v2.15.0 was released, no new Git for Windows v2.14.x version would be released). Indicators for imminent maintenance releases of Git are: + +- The Git maintainer sometimes talks about this in the preamble of the ["What's cooking in git.git" mails](https://public-inbox.org/git/?q=s%3A%22what%27s+cooking%22+AND+f%3Agitster%40pobox.com). +- The [`maint` in git.git](https://github.com/git/git/commits/maint) accumulates critical patches. + +Finally, Git for Windows is sometimes released in "out-of-band" versions, when critical fixes specific to Git for Windows necessitate it. These out-of-band versions are indicated by appending a `(2)` to the latest release (or `(3)`, `(4)`, etc). Examples for such out-of-band versions include: [Git for Windows v2.15.1(2)](https://github.com/git-for-windows/git/releases/tag/v2.15.1.windows.2) and [Git for Windows v2.16.1(4)](https://github.com/git-for-windows/git/releases/tag/v2.16.1.windows.4). + +## What is the relationship between *Git for Windows* and *msysGit*? + +*Git for Windows* used to be developed using the development environment called "msysGit", but roughly coinciding with Git 2.1, msysGit was superseded by a new development environment: the [Git for Windows SDK](https://github.com/git-for-windows/build-extra/releases). See [here](https://github.com/git-for-windows/git/wiki/Updating-your-SDK) to get a copy. + +## How do I update *Git for Windows* upon new releases? + +This depends on how you installed *Git for Windows*. The bundle installation requires you to download and install the new version. Any customizations you made will be kept as long as you did so in the appropriate configuration folders. + +For advanced users working with the *Git for Windows* SDK `pacman` is available as a package manager. See [Package management](Package-management) + +## How do I check the release hash and release notes + +For hashes see https://github.com/git-for-windows/git/releases + +For (G4W) release notes see the [build-extra repo](https://github.com/git-for-windows/build-extra/blob/master/ReleaseNotes.md), or the top level of your installation (e.g. [C:\Program Files\Git\ReleaseNotes.html](http://www.example.com/Program%20Files/Git/ReleaseNotes.html) - via manual browsing). + +For extracting 7z/zip archives see [page](https://github.com/git-for-windows/git/wiki/Zip-Archives---extracting-the-released-archives). + +## Are there 'Nightly' builds of the latest and greatest + +The Git for Windows builds are not quite that frequent, but there are Snapshot builds listed at https://wingit.blob.core.windows.net/files/index.html + +These often 'fix' (or attempt fixes) recent issues before a new formal release. Check their commit notes and links to issues to see if your problem is included. + +## Some native console programs don't work when run from Git Bash. How to fix it? + +*Git for Windows* defaults to using [mintty](https://code.google.com/p/mintty/) terminal. Compared to default Windows console host, it provides normal multi-line cut&paste, working resizing, defaults to unicode font and avoids some bugs in the default console host. However it does not present itself as console to native applications (those *not* built with MSys or Cygwin), so in these applications: + + * Non-ascii output may be corrupted due to mismatch in character sets (MSys and Cygwin use utf-8 while Windows will fall back to the legacy dos codepages in this case). + * Interactive and full-screen applications won't work at all. + +There are several methods for working around these problems: + + * Run programs that have problems using the [`winpty`](https://github.com/rprichard/winpty) utility. This allows you to keep using the nicer mintty terminal, but can become unwieldy if you need the workaround for many programs. + * Modify the shortcut for Git Bash to run `bash` directly without `mintty` so it uses the default console host and configure it for "Quick Edit", reasonable size and scroll-back and suitable unicode font. You'll still have to live with the other quirks of console host. + * Install and use [ConEmu](http://conemu.github.io/). + +## I get errors trying to check out files with long path names. +Windows file paths are by default limited to 255 characters. Some repositories may have committed files which contain paths longer than the limit. By default, *Git for Windows* does not support long paths, and will print errors when trying to perform any operation on a long file name. Set the configuration property `core.longpaths` to true to allow certain Git operations to properly handle these files. See [this wiki page](https://github.com/git-for-windows/git/wiki/Git-cannot-create-a-file-or-directory-with-a-long-path) for more information. + +## Excel file modifications not always noticed. +Excel (and some other apps) do not update the *modified time* of its files which is used by Git to quickly detect changes. Rather Excel used the *change time* field. Git will notice the modifications if a `git status` is performed. See [issue 1000](https://github.com/git-for-windows/git/issues/1000#issuecomment-301611003) if you need more background. + +## How do I access a repository hosted on a Microsoft Team Foundation Server inside a Windows domain? + +The Microsoft Team Foundation Server is capable of hosting git repositories. If the server is a member of a windows domain, and your user account is in that domain, you can use domain authentication to identify yourself to the server, and can thus access git repositories without having to enter any credentials. For this to work, the server has to be configured to use domain authentication, _not_ NTLM authentication. The repository URL can be obtained from the TFS web interface, it may look like http://server.example.com:8080/tfs/TWA/TeamDev/_git/reponame. + +In order to instruct git to use domain authentication, prefix the server name with `:@`, like so: `http://:@server.example.com:8080/tfs/TWA/TeamDev/_git/reponame`. This is a special case of the usual `username:password@server` syntax, where both the `username` and `password` fields are empty. This causes git to look up and use your domain credentials. + +## I get "Permission denied (publickey)." when using git pull + +Some DSA keys are not considered secure anymore by OpenSSH 7. Adding "PubkeyAcceptedKeyTypes ssh-dss" to ~/.ssh/config helps. + +## Switch locale for git-bash launcher (of Git for Windows SDK) + +Some developers want to start git-bash (of Git for Windows SDK) with a different language. +To achieve this in windows following command could be placed inside the launcher: +`C:\Windows\System32\cmd.exe /c "set LANG=en_GB && start C:\git-sdk-64\git-bash.exe && exit"` +replace `en_GB` with your preferred locale. + +## I have errors while building the solution in Visual studio +(i.e. `fatal error C1083: Cannot open include file: 'openssl/ssl.h': No such file or directory`) + +Try to open the console and invoke `git\compat\vcbuild\vcpkg_install.bat`. Make sure that it has completed successfully, then clean and rebuild the solution. + +Ensure also that you are using proper Build Tools (v140). It's going by default in VS 2015. If you are using VS 2017, you need to install them manually. Do not upgrade the project to v141 - it can't be done automatically. + +## Licenses + +Reproduced from [Git for Windows' release notes](https://github.com/git-for-windows/build-extra/blob/master/ReleaseNotes.md#licenses): + +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. + +Git for Windows also contains Embedded CAcert Root Certificates. For more information please go to https://www.cacert.org/policy/RootDistributionLicense.php. + +This package contains software from a number of other projects including Bash, zlib, curl, tcl/tk, perl, MSYS2 and a number of libraries and utilities from the GNU project, licensed under the GNU General Public License. Likewise, it contains Perl which is dual licensed under the GNU General Public License and the Artistic License. From 48c2ba6ab4e9e9ce3ddb7c18088eb5ebad468a98 Mon Sep 17 00:00:00 2001 From: Kexy Biscuit Date: Fri, 22 Feb 2019 10:19:03 +0800 Subject: [PATCH 345/591] robmen/gitsetup#1 is closed, add new link to msi related files. --- FAQ.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/FAQ.md b/FAQ.md index 84d1b6795755ad..1c6793ae6fa705 100644 --- a/FAQ.md +++ b/FAQ.md @@ -14,7 +14,7 @@ More information here: [Git for Windows' prerequisites](https://gitforwindows.or There is currently no MSI package; there is an exe installer and a portable package. You are welcome to contribute a Pull Request that packages a new installer. -There is an existing Pull Request in development and looking for testers, please try out https://github.com/robmen/gitsetup/issues/1 and give feedback. +~There is an existing Pull Request in development and looking for testers, please try out https://github.com/robmen/gitsetup/issues/1 and give feedback.~ It's closed by now. Future development is happening [here](https://github.com/git-for-windows/build-extra/tree/master/msi/). In the meantime you could try: From 0f6a1eaac99e223ad57f7d92299eda0818c906a7 Mon Sep 17 00:00:00 2001 From: Kexy Biscuit Date: Mon, 25 Feb 2019 18:10:13 +0800 Subject: [PATCH 346/591] Add Microsoft Docs reference about TFS. --- FAQ.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/FAQ.md b/FAQ.md index 1c6793ae6fa705..e9f3d2bfb8b839 100644 --- a/FAQ.md +++ b/FAQ.md @@ -89,6 +89,8 @@ The Microsoft Team Foundation Server is capable of hosting git repositories. If In order to instruct git to use domain authentication, prefix the server name with `:@`, like so: `http://:@server.example.com:8080/tfs/TWA/TeamDev/_git/reponame`. This is a special case of the usual `username:password@server` syntax, where both the `username` and `password` fields are empty. This causes git to look up and use your domain credentials. +See also: [Clone an existing Git repo - Azure Repos](https://docs.microsoft.com/en-us/azure/devops/repos/git/clone) + ## I get "Permission denied (publickey)." when using git pull Some DSA keys are not considered secure anymore by OpenSSH 7. Adding "PubkeyAcceptedKeyTypes ssh-dss" to ~/.ssh/config helps. From 34a8ab03b0157669c82c9d92b6d742314a076fba Mon Sep 17 00:00:00 2001 From: Steve Lee Date: Sat, 16 Mar 2019 21:37:13 +0000 Subject: [PATCH 347/591] Cleaned up --- Updating-your-SDK.md | 51 ++++++++++++++------------------------------ 1 file changed, 16 insertions(+), 35 deletions(-) diff --git a/Updating-your-SDK.md b/Updating-your-SDK.md index bfe77316f82dd3..86d7b9caff1377 100644 --- a/Updating-your-SDK.md +++ b/Updating-your-SDK.md @@ -1,50 +1,31 @@ -# Get your own copy of the SDK +# Installing the SDK -You can initialize your own copy of the SDK via `git clone --depth=1 https://github.com/git-for-windows/git-sdk-64` (or `...-32` for 32-bit)... (select depth to taste). [#816](https://github.com/git-for-windows/git/issues/816) +The [Git for Windows SDK release](https://github.com/git-for-windows/build-extra/releases/latest) is a self extracting and auto executing 7-zip archive that clones the latest version of files in [Git for Windows SDK 64 repository](https://github.com/git-for-windows/git-sdk-64`) using a temporary bundled git. For the [32 bit version](https://github.com/git-for-windows/git-sdk-32`) it also performs a run time optimisation on cloned DLLs (rebase). +This was previously called the 'net installer', see below. It provides everyhting required to bootstrap a development environment, even if no git is available (or a unstable one is being worked on). -**** +It is also possible to manually extract the archive and then run `./setup-git-sdk.bat` in the Msys2 terminal window. + +Alternatively, you can also clone your own copy of the 64 bit SDK with `git clone --depth=1 https://github.com/git-for-windows/git-sdk-64` (or `...-32` for 32-bit)... (select depth to taste) (See #816). - -Extract from the [Git for Windows SDK release page](https://github.com/git-for-windows/build-extra/releases/latest). Note the Caution parts! - -# The SDK 'net installer' - -The SDK 'net installer' is a self-extracting archive containing a minimal -set of files needed to bootstrap an entire development environment to -compile and run Git for Windows. - -When run as executable, it automatically runs [`setup-git-sdk.bat`](https://github.com/git-for-windows/build-extra/blob/master/sdk-installer/setup-git-sdk.bat) after -extracting the files. Users who prefer to unpack the archive manually -with 7-Zip need to run that batch file manually, too. The script is -extensively commented to assist in understanding the installation process -and issues. - -The files contained in the net installer are parts of MSYS2's -'msys2-runtime', 'pacman' and 'gnupg' packages, carefully selected to -keep the size of the installer small yet still allowing to use the -Pacman package manager to initialize a full-fledged MSYS2 environment +The SDK contains core parts of MSYS2'Runtime, MinGW, 'pacman' and 'gnupg' packages, carefully selected to +keep the size small yet still allowing to use the Pacman package manager to initialize a full-fledged MSYS2 environment plus Git for Windows' packages. -The bootstrap script needs to force-install the packages because the net -installer comes without any package information and Pacman would -therefore refuse to overwrite the files from above-mentioned packages. - -# To keep the development environment up-to-date +# Updating the installed SDK -To keep the development environment up-to-date, developers need to run +To keep the SDK up-to-date, periodically run pacman -Syuu - # If core-packages are updated during that call you MUST restart MSYS2, - # follow instructions and repeat. + # If core-packages are updated during that call you are promted to + # restart MSYS2 with exiting back to the shell. + # Follow these instructions and repeat: pacman -Syu -from time to time. - -### Caution (update-core) +## Explanation Core packages like the `msys2-runtime`, `bash` or `pacman` itself should be updated -via the `pacman -Syuu` command [was X`update-core` script X]. Because those core packages are linked to the +with the `pacman -Syu` command [was X`update-core` script X]. Because those core packages are linked to the `msys2-runtime` (and each other), and updating the runtime "in flight" results most often in heap corruption as far as MSYS2 is concerned. @@ -52,7 +33,7 @@ The old `update-core` script has been retired, see https://github.com/msys2/MSYS ## Alternative Method -An alternative method is to start `git-cmd.exe` and run `pacman -Sy --needed msys2-runtime` and `pacman -S --needed pacman bash`, because that ensures that no obsolete binary continues to be used after the +An alternative method is to start `git-cmd.exe` from within the MSYS2 shell and run `pacman -Sy --needed msys2-runtime && pacman -S --needed pacman bash`. This ensures that no obsolete binary continues to be used after the update. ### See Also: From 2f12cff04839f3de5523e23ba19097b0b9314ca3 Mon Sep 17 00:00:00 2001 From: Steve Lee Date: Sat, 16 Mar 2019 21:43:07 +0000 Subject: [PATCH 348/591] Tweak --- Updating-your-SDK.md | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/Updating-your-SDK.md b/Updating-your-SDK.md index 86d7b9caff1377..d6d8359c9ed340 100644 --- a/Updating-your-SDK.md +++ b/Updating-your-SDK.md @@ -2,23 +2,23 @@ The [Git for Windows SDK release](https://github.com/git-for-windows/build-extra/releases/latest) is a self extracting and auto executing 7-zip archive that clones the latest version of files in [Git for Windows SDK 64 repository](https://github.com/git-for-windows/git-sdk-64`) using a temporary bundled git. For the [32 bit version](https://github.com/git-for-windows/git-sdk-32`) it also performs a run time optimisation on cloned DLLs (rebase). -This was previously called the 'net installer', see below. It provides everyhting required to bootstrap a development environment, even if no git is available (or a unstable one is being worked on). +This was previously called the 'net installer', see below. It provides everything required to bootstrap a development environment, even if no git is available (or a unstable one is being worked on). It is also possible to manually extract the archive and then run `./setup-git-sdk.bat` in the Msys2 terminal window. -Alternatively, you can also clone your own copy of the 64 bit SDK with `git clone --depth=1 https://github.com/git-for-windows/git-sdk-64` (or `...-32` for 32-bit)... (select depth to taste) (See #816). +Alternatively, you can also clone your own copy of the 64 bit SDK with `git clone --depth=1 https://github.com/git-for-windows/git-sdk-64` (or `...-32` for 32-bit)... (select depth to taste) (See #816). The repository contains exes and DLLS so you should run the rebase script for the 32 bit version. -The SDK contains core parts of MSYS2'Runtime, MinGW, 'pacman' and 'gnupg' packages, carefully selected to -keep the size small yet still allowing to use the Pacman package manager to initialize a full-fledged MSYS2 environment +The SDK contains core parts of MSYS2 Runtime, MinGW, 'pacman' and 'gnupg' packages, carefully selected to +keep the size small yet still allowing use of the 'pacman' package manager to initialize a full-fledged MSYS2 environment plus Git for Windows' packages. # Updating the installed SDK To keep the SDK up-to-date, periodically run - pacman -Syuu - # If core-packages are updated during that call you are promted to - # restart MSYS2 with exiting back to the shell. + pacman -Syu + # If core-packages are updated by this you are promted + # to restart MSYS2 without exiting back to the shell. # Follow these instructions and repeat: pacman -Syu From 490412e93b374be32a8f5ebacffed1a9431ed6cb Mon Sep 17 00:00:00 2001 From: MultiplyByZer0 Date: Sat, 30 Mar 2019 02:09:38 -0400 Subject: [PATCH 349/591] The pound signs are ugly and unnecessary. --- _Footer.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/_Footer.md b/_Footer.md index 65a62f83f0e8b2..b923b0d25dbcc6 100644 --- a/_Footer.md +++ b/_Footer.md @@ -1,3 +1,3 @@ -# > # ## ### ## # *This is the _Git for Windows_ wiki. See [how-to-participate](https://gitforwindows.org/governance-model.html). +This is the _Git for Windows_ wiki. See [how-to-participate](https://gitforwindows.org/governance-model.html). From e7f3aee079c01124a744cf70b114f7867f92ec31 Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Tue, 2 Apr 2019 23:49:36 +0100 Subject: [PATCH 350/591] extra comment for second pass (use pull), and for local tests. --- Rebasing-Git-for-Windows.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/Rebasing-Git-for-Windows.md b/Rebasing-Git-for-Windows.md index b8d4bd8afc3b94..211d62436006fa 100644 --- a/Rebasing-Git-for-Windows.md +++ b/Rebasing-Git-for-Windows.md @@ -10,6 +10,7 @@ To do a *rebase* of the *Git for Windows* source onto a new [upstream](https://g `cd /usr/src/build-extra` `git fetch` `git checkout master` + (`git pull` if your branch is behind the upstream) 3. Working directory set to current *Git for Windows* source. `cd /usr/src/git` 4. Added [upstream](https://github.com/git/git) as a remote. @@ -22,6 +23,7 @@ To do a *rebase* of the *Git for Windows* source onto a new [upstream](https://g 2. Run the `shears.sh` script to build up the actual *rebase* script. `../build-extra/./shears.sh --merging --onto v2.3.4 $BASE` Note: `v2.3.4` is a `tag` in the remote `git`. + See the script if you are testing changes initiated in a local branch of the git upstream. 3. The *rebase* should start automatically and occasionally stop if it hits any merge conflicts. Resolve those conflicts and then continue the rebase. `git rebase --continue` From ee8c764e32eb7d73dc0c8f58fb4a1ff8626a0de5 Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Fri, 5 Apr 2019 00:25:49 +0100 Subject: [PATCH 351/591] added extra checks for $BASE and suggested readers look at range-diff --- Rebasing-Git-for-Windows.md | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/Rebasing-Git-for-Windows.md b/Rebasing-Git-for-Windows.md index 211d62436006fa..415788e9829774 100644 --- a/Rebasing-Git-for-Windows.md +++ b/Rebasing-Git-for-Windows.md @@ -19,10 +19,13 @@ To do a *rebase* of the *Git for Windows* source onto a new [upstream](https://g # Starting the *rebase* 1. Find the commit of the last *rebase* and remember it. - `BASE="$(git rev-parse ":/Start the merging-rebase")"` + `BASE="$(git rev-parse ":/Start the merging-rebase")"` or possibly + `BASE="$(git rev-parse HEAD^{"/Start the merging-rebase}")"` if there have been + trial merging rebases on other branches. Check with + `git log -1 $BASE` and `git branch -a --contains $BASE`. 2. Run the `shears.sh` script to build up the actual *rebase* script. `../build-extra/./shears.sh --merging --onto v2.3.4 $BASE` - Note: `v2.3.4` is a `tag` in the remote `git`. + Note: `v2.3.4` is a `tag` in the remote `git`. See the script if you are testing changes initiated in a local branch of the git upstream. 3. The *rebase* should start automatically and occasionally stop if it hits any merge conflicts. Resolve those conflicts and then continue the rebase. `git rebase --continue` @@ -40,3 +43,5 @@ To do a *rebase* of the *Git for Windows* source onto a new [upstream](https://g >So meta. >When there is a line that starts with a `-` or a `+` but then continues with a space, that's good! >It means that the context of our changes changed. + +The newer `git range-diff` may also be used. From ee55118efb90b0b4d551a02f13b728155b94565a Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Fri, 5 Apr 2019 16:11:00 +0100 Subject: [PATCH 352/591] What I'm Learning Is - Hopefully this will bridge the gap for new 'devs to try out the Upstream->GfW->personal release process. --- ...flicts---Resolving-and-Remembering-them.md | 21 +++++++++++++++++++ 1 file changed, 21 insertions(+) create mode 100644 Merge-Conflicts---Resolving-and-Remembering-them.md diff --git a/Merge-Conflicts---Resolving-and-Remembering-them.md b/Merge-Conflicts---Resolving-and-Remembering-them.md new file mode 100644 index 00000000000000..c02822c877fe7f --- /dev/null +++ b/Merge-Conflicts---Resolving-and-Remembering-them.md @@ -0,0 +1,21 @@ +Work in Progress as I try and work out how to do this (05-04-2019).. + +When building a new release for Git-for-Windows, the full range of Windows patches the maintainer applies need to be moved ([`rebase`](https://git-scm.com/docs/git-rebase)d) from being on top of the old upstream Git, to being on top of the new upstream release. + +There is a [process](https://github.com/git-for-windows/git/wiki/Rebasing-Git-for-Windows), a script and the support of the merging-rebase code, but still there maybe conflicts, old and new, especially if some of the Windows code has been adopted upstream in a different form. + +This note looks at how to remember those resolutions, reuse them, and to learn from previous Git-for-Windows rebases. +The magic is in the [REuse REcorded REsolution (rerere)](https://git-scm.com/docs/git-rerere) command and it's underlying database. + +The documentation is terse, so let's also point to some on-line articles: +* [Fun with rerere](https://gitster.livejournal.com/41795.html) from the Git maintainer +* [Fix conflicts only once with git rerere](https://medium.com/@porteneuve/fix-conflicts-only-once-with-git-rerere-7d116b2cec67) +* [Do you even rerere?](https://blog.theodo.fr/2015/01/do-you-even-rerere/) +* [rerere-train.sh](https://github.com/git/git/blob/master/contrib/rerere-train.sh) use the 'blame' button for extra commit info. +* [Are there any downsides to enabling git rerere?](https://stackoverflow.com/q/5519244/717355) Not really, but read and learn. +* [7.9 Git Tools (book) - Rerere](https://git-scm.com/book/en/v2/Git-Tools-Rerere). + +So, enable `rerere` - `git config --global rerere.enabled true`. + +Determine a previous Git-for-Windows merging-rebase end points and run the `contrib/rerere-train.sh` + From 49fc2a23c538d43527ffc4390849e1b4faaf3851 Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Fri, 5 Apr 2019 16:12:34 +0100 Subject: [PATCH 353/591] added Merge-Conflicts---Resolving-and-Remembering-them --- 0.-Index.md | 1 + 1 file changed, 1 insertion(+) diff --git a/0.-Index.md b/0.-Index.md index 98365857d3a7e2..9cf0a6cf620d2c 100644 --- a/0.-Index.md +++ b/0.-Index.md @@ -21,6 +21,7 @@ This is for the poor souls in corporate IE environments who can't expand the pag * [Issue reporting guidelines](https://github.com/git-for-windows/git/wiki/Issue-reporting-guidelines) * [Making a portable Git](https://github.com/git-for-windows/git/wiki/Making-a-portable-Git) * [Making an installer](https://github.com/git-for-windows/git/wiki/Making-an-installer) +* [Merge Conflicts Resolving and Remembering them](https://github.com/git-for-windows/git/wiki/Merge-Conflicts---Resolving-and-Remembering-them) * [MinGit is Git for Windows Applications](https://github.com/git-for-windows/git/wiki/MinGit) * [MSYS2 Notes](https://github.com/git-for-windows/git/wiki/MSYS2-Notes) * [OpenSSH Integration with Pageant](https://github.com/git-for-windows/git/wiki/OpenSSH-Integration-with-Pageant) From 33c702ad224f15072fb2c930379390c690ffd7bf Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Fri, 5 Apr 2019 16:15:12 +0100 Subject: [PATCH 354/591] annded link to 'Merge Conflicts Resolving and Remembering them' --- Rebasing-Git-for-Windows.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Rebasing-Git-for-Windows.md b/Rebasing-Git-for-Windows.md index 415788e9829774..3eca12a8e50901 100644 --- a/Rebasing-Git-for-Windows.md +++ b/Rebasing-Git-for-Windows.md @@ -27,7 +27,7 @@ To do a *rebase* of the *Git for Windows* source onto a new [upstream](https://g `../build-extra/./shears.sh --merging --onto v2.3.4 $BASE` Note: `v2.3.4` is a `tag` in the remote `git`. See the script if you are testing changes initiated in a local branch of the git upstream. -3. The *rebase* should start automatically and occasionally stop if it hits any merge conflicts. Resolve those conflicts and then continue the rebase. +3. The *rebase* should start automatically and occasionally stop if it hits any merge conflicts. Resolve those conflicts (see also [Merge Conflicts Resolving and Remembering them](https://github.com/git-for-windows/git/wiki/Merge-Conflicts---Resolving-and-Remembering-them)) and then continue the rebase. `git rebase --continue` # Verifying the *rebase* From b13943157dc104d7df1d32781d89b66a66c2c551 Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Fri, 5 Apr 2019 16:25:12 +0100 Subject: [PATCH 355/591] Updated Rebasing Git for Windows (markdown) --- Rebasing-Git-for-Windows.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/Rebasing-Git-for-Windows.md b/Rebasing-Git-for-Windows.md index 3eca12a8e50901..2bbf3732174a1c 100644 --- a/Rebasing-Git-for-Windows.md +++ b/Rebasing-Git-for-Windows.md @@ -3,6 +3,8 @@ To do a *rebase* of the *Git for Windows* source onto a new [upstream](https://g # Assumptions 1. You want to *rebase* onto a new [upstream](https://github.com/git/git) release tagged as `v2.3.4` 2. The latest *rebase* was done onto a [upstream](https://github.com/git/git) release tagged as `v2.3.3` +3. the `origin/master` below means remote https://github.com/git-for-windows/git, its `master` branch. + You may have them named differently. # Preconditions 1. A working [Git for Windows SDK](https://gitforwindows.org/#download-sdk). From fee04e875ef1e786a0037f34bd9a82fafdc1a5eb Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Fri, 5 Apr 2019 17:52:37 +0100 Subject: [PATCH 356/591] and rerere.autoupdate true --- Merge-Conflicts---Resolving-and-Remembering-them.md | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/Merge-Conflicts---Resolving-and-Remembering-them.md b/Merge-Conflicts---Resolving-and-Remembering-them.md index c02822c877fe7f..77a5ecd431f2d6 100644 --- a/Merge-Conflicts---Resolving-and-Remembering-them.md +++ b/Merge-Conflicts---Resolving-and-Remembering-them.md @@ -15,7 +15,8 @@ The documentation is terse, so let's also point to some on-line articles: * [Are there any downsides to enabling git rerere?](https://stackoverflow.com/q/5519244/717355) Not really, but read and learn. * [7.9 Git Tools (book) - Rerere](https://git-scm.com/book/en/v2/Git-Tools-Rerere). -So, enable `rerere` - `git config --global rerere.enabled true`. +So, enable `rerere` - `git config --global rerere.enabled true`, +consider setting `git config --global rerere.autoupdate true` and away you go! Determine a previous Git-for-Windows merging-rebase end points and run the `contrib/rerere-train.sh` From 2df998ecc4864ce5ea85b6e4c1dc06085e3fd944 Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Fri, 5 Apr 2019 22:10:30 +0100 Subject: [PATCH 357/591] rerere-train --- Merge-Conflicts---Resolving-and-Remembering-them.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/Merge-Conflicts---Resolving-and-Remembering-them.md b/Merge-Conflicts---Resolving-and-Remembering-them.md index 77a5ecd431f2d6..5171880a36eeea 100644 --- a/Merge-Conflicts---Resolving-and-Remembering-them.md +++ b/Merge-Conflicts---Resolving-and-Remembering-them.md @@ -9,8 +9,8 @@ The magic is in the [REuse REcorded REsolution (rerere)](https://git-scm.com/doc The documentation is terse, so let's also point to some on-line articles: * [Fun with rerere](https://gitster.livejournal.com/41795.html) from the Git maintainer -* [Fix conflicts only once with git rerere](https://medium.com/@porteneuve/fix-conflicts-only-once-with-git-rerere-7d116b2cec67) -* [Do you even rerere?](https://blog.theodo.fr/2015/01/do-you-even-rerere/) +* [Fix conflicts only once with git rerere](https://medium.com/@porteneuve/fix-conflicts-only-once-with-git-rerere-7d116b2cec67) Nice graphs and examples. +* [Do you even rerere?](https://blog.theodo.fr/2015/01/do-you-even-rerere/) Good discussion, including `rerere-train`. * [rerere-train.sh](https://github.com/git/git/blob/master/contrib/rerere-train.sh) use the 'blame' button for extra commit info. * [Are there any downsides to enabling git rerere?](https://stackoverflow.com/q/5519244/717355) Not really, but read and learn. * [7.9 Git Tools (book) - Rerere](https://git-scm.com/book/en/v2/Git-Tools-Rerere). From f4e3decc177b4648d53148704ff18318413b79ac Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Fri, 5 Apr 2019 22:30:31 +0100 Subject: [PATCH 358/591] more rerere-train'ing stuff --- Merge-Conflicts---Resolving-and-Remembering-them.md | 3 +++ 1 file changed, 3 insertions(+) diff --git a/Merge-Conflicts---Resolving-and-Remembering-them.md b/Merge-Conflicts---Resolving-and-Remembering-them.md index 5171880a36eeea..ebc09ae57e6ee0 100644 --- a/Merge-Conflicts---Resolving-and-Remembering-them.md +++ b/Merge-Conflicts---Resolving-and-Remembering-them.md @@ -13,6 +13,7 @@ The documentation is terse, so let's also point to some on-line articles: * [Do you even rerere?](https://blog.theodo.fr/2015/01/do-you-even-rerere/) Good discussion, including `rerere-train`. * [rerere-train.sh](https://github.com/git/git/blob/master/contrib/rerere-train.sh) use the 'blame' button for extra commit info. * [Are there any downsides to enabling git rerere?](https://stackoverflow.com/q/5519244/717355) Not really, but read and learn. +* [Smarter rebase avoiding redundant work?](https://stackoverflow.com/q/10601541/717355) more rerere-train answers * [7.9 Git Tools (book) - Rerere](https://git-scm.com/book/en/v2/Git-Tools-Rerere). So, enable `rerere` - `git config --global rerere.enabled true`, @@ -20,3 +21,5 @@ consider setting `git config --global rerere.autoupdate true` and away you go! Determine a previous Git-for-Windows merging-rebase end points and run the `contrib/rerere-train.sh` +Remember the parameters passed to rerere-train are `` (apparently) for selecting the training set. + From d9438cdbe103e5d6da299c3b6fd9fb78d4571482 Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Sat, 6 Apr 2019 10:56:35 +0100 Subject: [PATCH 359/591] Added large file size issue --- FAQ.md | 3 +++ 1 file changed, 3 insertions(+) diff --git a/FAQ.md b/FAQ.md index e9f3d2bfb8b839..5060e1a0c810f7 100644 --- a/FAQ.md +++ b/FAQ.md @@ -80,6 +80,9 @@ There are several methods for working around these problems: ## I get errors trying to check out files with long path names. Windows file paths are by default limited to 255 characters. Some repositories may have committed files which contain paths longer than the limit. By default, *Git for Windows* does not support long paths, and will print errors when trying to perform any operation on a long file name. Set the configuration property `core.longpaths` to true to allow certain Git operations to properly handle these files. See [this wiki page](https://github.com/git-for-windows/git/wiki/Git-cannot-create-a-file-or-directory-with-a-long-path) for more information. +## The installed files are duplicated and look massive - Why? +All the apparent copies are simply hard links - see Issue 1997 [Use symbolic links for libexec](https://github.com/git-for-windows/git/issues/1997) for more details. + ## Excel file modifications not always noticed. Excel (and some other apps) do not update the *modified time* of its files which is used by Git to quickly detect changes. Rather Excel used the *change time* field. Git will notice the modifications if a `git status` is performed. See [issue 1000](https://github.com/git-for-windows/git/issues/1000#issuecomment-301611003) if you need more background. From 406c667d29ad4c0739a91936d68f684dbd11ff83 Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Sat, 6 Apr 2019 13:26:31 +0100 Subject: [PATCH 360/591] Updated Merge Conflicts Resolving and Remembering them (markdown) --- Merge-Conflicts---Resolving-and-Remembering-them.md | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/Merge-Conflicts---Resolving-and-Remembering-them.md b/Merge-Conflicts---Resolving-and-Remembering-them.md index ebc09ae57e6ee0..df388d75eb2783 100644 --- a/Merge-Conflicts---Resolving-and-Remembering-them.md +++ b/Merge-Conflicts---Resolving-and-Remembering-them.md @@ -1,4 +1,4 @@ -Work in Progress as I try and work out how to do this (05-04-2019).. +Work in Progress as I try and work out how to do this (06-04-2019).. When building a new release for Git-for-Windows, the full range of Windows patches the maintainer applies need to be moved ([`rebase`](https://git-scm.com/docs/git-rebase)d) from being on top of the old upstream Git, to being on top of the new upstream release. @@ -23,3 +23,10 @@ Determine a previous Git-for-Windows merging-rebase end points and run the `cont Remember the parameters passed to rerere-train are `` (apparently) for selecting the training set. +### From the git List +Threads about the internal workings: + +[saving and replaying multiple variants with rerere](https://public-inbox.org/git/1442275050-30497-1-git-send-email-gitster@pobox.com/) 2015-09-14 +[Should rerere auto-update a merge resolution?](https://public-inbox.org/git/CACPiFCJH7RSb_rz6M6ADuGi0q+oeWYhE1fNMQC0EUcCn_kCJwg@mail.gmail.com/) 2017-08-23 +[rebase: use OPT_RERERE_AUTOUPDATE()](https://public-inbox.org/git/20190319190317.6632-4-phillip.wood123@gmail.com/#r) 2019-03-19 +[git/Documentation/technical/rerere.txt](https://github.com/git/git/blob/master/Documentation/technical/rerere.txt) \ No newline at end of file From a4d964067e6b12cef02fe8f6f251f10bc1e56664 Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Sat, 6 Apr 2019 13:28:28 +0100 Subject: [PATCH 361/591] Updated Merge Conflicts Resolving and Remembering them (markdown) --- Merge-Conflicts---Resolving-and-Remembering-them.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Merge-Conflicts---Resolving-and-Remembering-them.md b/Merge-Conflicts---Resolving-and-Remembering-them.md index df388d75eb2783..4ecee288e2b261 100644 --- a/Merge-Conflicts---Resolving-and-Remembering-them.md +++ b/Merge-Conflicts---Resolving-and-Remembering-them.md @@ -29,4 +29,4 @@ Threads about the internal workings: [saving and replaying multiple variants with rerere](https://public-inbox.org/git/1442275050-30497-1-git-send-email-gitster@pobox.com/) 2015-09-14 [Should rerere auto-update a merge resolution?](https://public-inbox.org/git/CACPiFCJH7RSb_rz6M6ADuGi0q+oeWYhE1fNMQC0EUcCn_kCJwg@mail.gmail.com/) 2017-08-23 [rebase: use OPT_RERERE_AUTOUPDATE()](https://public-inbox.org/git/20190319190317.6632-4-phillip.wood123@gmail.com/#r) 2019-03-19 -[git/Documentation/technical/rerere.txt](https://github.com/git/git/blob/master/Documentation/technical/rerere.txt) \ No newline at end of file +[git/Documentation/technical/rerere.txt](https://github.com/git/git/blob/master/Documentation/technical/rerere.txt) committed on 5 Aug 2018 From 82ba7606ac38c37623ec4cc51fe892a17377473b Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Sat, 6 Apr 2019 13:49:57 +0100 Subject: [PATCH 362/591] Updated Merge Conflicts Resolving and Remembering them (markdown) --- Merge-Conflicts---Resolving-and-Remembering-them.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/Merge-Conflicts---Resolving-and-Remembering-them.md b/Merge-Conflicts---Resolving-and-Remembering-them.md index 4ecee288e2b261..0aafce0ba6aec7 100644 --- a/Merge-Conflicts---Resolving-and-Remembering-them.md +++ b/Merge-Conflicts---Resolving-and-Remembering-them.md @@ -30,3 +30,5 @@ Threads about the internal workings: [Should rerere auto-update a merge resolution?](https://public-inbox.org/git/CACPiFCJH7RSb_rz6M6ADuGi0q+oeWYhE1fNMQC0EUcCn_kCJwg@mail.gmail.com/) 2017-08-23 [rebase: use OPT_RERERE_AUTOUPDATE()](https://public-inbox.org/git/20190319190317.6632-4-phillip.wood123@gmail.com/#r) 2019-03-19 [git/Documentation/technical/rerere.txt](https://github.com/git/git/blob/master/Documentation/technical/rerere.txt) committed on 5 Aug 2018 +[Make git-rerere a builtin](https://public-inbox.org/git/Pine.LNX.4.63.0612201738000.19693@wbgn013.biozentrum.uni-wuerzburg.de/) 2006-12-20 convert from a perl script + From 4cef1c44bf2cf1bcab625ae37bf2ef5f46154847 Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Sat, 6 Apr 2019 15:39:54 +0100 Subject: [PATCH 363/591] cross link to CONTRIBUTING.md within the code --- How-to-participate.md | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/How-to-participate.md b/How-to-participate.md index 7b1d952369ae93..6e32e63237271e 100644 --- a/How-to-participate.md +++ b/How-to-participate.md @@ -6,11 +6,14 @@ On [the mailing list](http://groups.google.com/group/git-for-windows) or on [the # Add documentation -A lot of documentation wants to be written, still. A good place is [the Git for Windows wiki](https://github.com/git-for-windows/git/wiki). Tutorials, step by step instructions and general background information, etc. +A lot of documentation wants to be written, still. A good place is [the Git for Windows wiki](https://github.com/git-for-windows/git/wiki). Tutorials, step by step instructions and general background information, etc. Even just keep the links up to date and reporting inconsistencies is helpful. # Fix bugs or add features in the Git code itself -Download [the SDK](https://gitforwindows.org/#download-sdk) and build Git. Also have a look at [this page](https://github.com/git-for-windows/git/wiki/Building-Git) for tips and tricks revolving around building and debugging Git. +Download [the SDK](https://gitforwindows.org/#download-sdk) and build Git. See the [CONTRIBUTING.md](https://github.com/git-for-windows/git/blob/master/CONTRIBUTING.md) page/file + + +Also have a look at [this page](https://github.com/git-for-windows/git/wiki/Building-Git) for tips and tricks revolving around building and debugging Git. Please also sign off your work, as [asked by the Git project](https://github.com/git/git/blob/v2.3.5/Documentation/SubmittingPatches#L234-L286) From 9b05187df5445d6666c17e03ba765f4846bb7864 Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Sat, 6 Apr 2019 22:41:05 +0100 Subject: [PATCH 364/591] discuss what needs remembering, and an alternate description of how the fake merge works, and how to 'replace' it. --- ...-Conflicts---Resolving-and-Remembering-them.md | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/Merge-Conflicts---Resolving-and-Remembering-them.md b/Merge-Conflicts---Resolving-and-Remembering-them.md index 0aafce0ba6aec7..ccfe4a6ee230a1 100644 --- a/Merge-Conflicts---Resolving-and-Remembering-them.md +++ b/Merge-Conflicts---Resolving-and-Remembering-them.md @@ -32,3 +32,18 @@ Threads about the internal workings: [git/Documentation/technical/rerere.txt](https://github.com/git/git/blob/master/Documentation/technical/rerere.txt) committed on 5 Aug 2018 [Make git-rerere a builtin](https://public-inbox.org/git/Pine.LNX.4.63.0612201738000.19693@wbgn013.biozentrum.uni-wuerzburg.de/) 2006-12-20 convert from a perl script +### Patch series, Rebase and Merge conflicts: When and where + +For the rerere (redo) database, it is worth taking a few moments to consider the difference between the conflict resolution that you would perform during a rebase when a patch fails to merge cleanly, and the conflict resolution for a merge. + +For a subsequent rebase, of the repeating merging-rebase kind, it is easy to forget that the _patches_ being forward ported to the new base commit _already_ contain the previous resolution, so will not conflict next time, unless the upstream has changed, whereupon you have a _new_ conflict to resolve. + +This partially extends to the merges _within_ the merging-rebase. If previous rebases have tidied the merging branches to avoid merge conflicts then there will be no resolutions to record. However if the cleanest approach was to resolve at merge, then the merge resolution can (should) be learned. Further, if you also had upstream changes and resolutions in the branches being merged, there may still be further residual merge resolutions to be performed. So unless the merges were clean then these are all **new** merge resolutions that should be learned (or relearned) for later reuse in redoing the next merging rebase. + +Moreover, if you are rebasing a series that has temporary merges from upstream or other independent side merges (?Cousins?), then these resolutions will need to be remembered for future merging-rebase is repeated (after dropping those merges from the 'todo' list) + +### merging-rebase, as used in Git for Windows. + +When upstream provides a tagged release, we create a commit with duplicated content tree (same oid hash) that has parents of: the upstream release and our _previous_ release. This 'fake merge', with commit message title `Start the merging-rebase`, along with its predecessor fake merge, provides anchors for the rebase of the patch series. + +A side effect is that, via the second parent line we have many repetitions of the same patch series when searching via `blame` or `grep`, or doing a `git bisect`. The effect can be mitigated by inserting a temporary `git replace` of the `Start the merging-rebase`merge commit, by its first (upstream) parent, making the merge disappear, along with all those historical duplicate patches. It becomes: upstream Git with Windows patches on top - simple. From 1a4f95c3982b8594ac9f402aa105c6ec1ed9c01c Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Sat, 6 Apr 2019 22:48:33 +0100 Subject: [PATCH 365/591] more (~last of not many) git list references --- Merge-Conflicts---Resolving-and-Remembering-them.md | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/Merge-Conflicts---Resolving-and-Remembering-them.md b/Merge-Conflicts---Resolving-and-Remembering-them.md index ccfe4a6ee230a1..42659ce97202a4 100644 --- a/Merge-Conflicts---Resolving-and-Remembering-them.md +++ b/Merge-Conflicts---Resolving-and-Remembering-them.md @@ -30,7 +30,9 @@ Threads about the internal workings: [Should rerere auto-update a merge resolution?](https://public-inbox.org/git/CACPiFCJH7RSb_rz6M6ADuGi0q+oeWYhE1fNMQC0EUcCn_kCJwg@mail.gmail.com/) 2017-08-23 [rebase: use OPT_RERERE_AUTOUPDATE()](https://public-inbox.org/git/20190319190317.6632-4-phillip.wood123@gmail.com/#r) 2019-03-19 [git/Documentation/technical/rerere.txt](https://github.com/git/git/blob/master/Documentation/technical/rerere.txt) committed on 5 Aug 2018 -[Make git-rerere a builtin](https://public-inbox.org/git/Pine.LNX.4.63.0612201738000.19693@wbgn013.biozentrum.uni-wuerzburg.de/) 2006-12-20 convert from a perl script +[git rerere unresolve file](https://public-inbox.org/git/200911211958.40872.j6t@kdbg.org/) 2009-11-21 patch series +[Make git-rerere a builtin](https://public-inbox.org/git/Pine.LNX.4.63.0612201738000.19693@wbgn013.biozentrum.uni-wuerzburg.de/) 2006-12-20 convert from a perl script +[Add a test for git-rerere](https://public-inbox.org/git/Pine.LNX.4.63.0612201737190.19693@wbgn013.biozentrum.uni-wuerzburg.de/) 2006-12-20 ### Patch series, Rebase and Merge conflicts: When and where From b6ea546e243ec2ed83ce21886b269c034173b97a Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Sat, 6 Apr 2019 22:52:05 +0100 Subject: [PATCH 366/591] commas, --- Merge-Conflicts---Resolving-and-Remembering-them.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Merge-Conflicts---Resolving-and-Remembering-them.md b/Merge-Conflicts---Resolving-and-Remembering-them.md index 42659ce97202a4..78c3d94c025e1a 100644 --- a/Merge-Conflicts---Resolving-and-Remembering-them.md +++ b/Merge-Conflicts---Resolving-and-Remembering-them.md @@ -48,4 +48,4 @@ Moreover, if you are rebasing a series that has temporary merges from upstream o When upstream provides a tagged release, we create a commit with duplicated content tree (same oid hash) that has parents of: the upstream release and our _previous_ release. This 'fake merge', with commit message title `Start the merging-rebase`, along with its predecessor fake merge, provides anchors for the rebase of the patch series. -A side effect is that, via the second parent line we have many repetitions of the same patch series when searching via `blame` or `grep`, or doing a `git bisect`. The effect can be mitigated by inserting a temporary `git replace` of the `Start the merging-rebase`merge commit, by its first (upstream) parent, making the merge disappear, along with all those historical duplicate patches. It becomes: upstream Git with Windows patches on top - simple. +A side effect is that, via the second parent line, we have many repetitions of the same patch series when searching via `blame` or `grep`, or doing a `git bisect`. The effect can be mitigated by inserting a temporary `git replace` of the `Start the merging-rebase`merge commit, by its first (upstream) parent, making the merge disappear, along with all those historical duplicate patches. It becomes: upstream Git, with Windows patches on top - simple. From dc658446b87abd837b2d1ae785a6f6c74690f6a6 Mon Sep 17 00:00:00 2001 From: Rafal Rogala <35906077+HeartbliT@users.noreply.github.com> Date: Sun, 14 Apr 2019 18:43:54 +0200 Subject: [PATCH 367/591] Created mortal (markdown) --- mortal.md | 68 +++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 68 insertions(+) create mode 100644 mortal.md diff --git a/mortal.md b/mortal.md new file mode 100644 index 00000000000000..1f7a687dc33da9 --- /dev/null +++ b/mortal.md @@ -0,0 +1,68 @@ +# Privileged remote app + +This is a privileged app template that demonstrates the usage of [`XMLHttpRequest`](https://developer.mozilla.org/docs/Web/API/XMLHttpRequest) and [`systemXHR`](https://developer.mozilla.org/Apps/Reference/Firefox_OS_device_APIs#systemXHR) to load remote content from a server, and includes a properly configured manifest file with the right app type (`privileged`) and required permissions, in order to use those APIs. + +This is part of the [mortar](https://github.com/mozilla/mortar/) template collection for building [Open Web Apps](https://developer.mozilla.org/Apps). + +## Obtaining + +There are a few ways to get this template: + +If you use [Git](http://www.git-scm.com/): + +````bash +git clone https://github.com/mozilla/mortar-privileged-remote-app.git +```` + +Or download the latest version in this [ZIP file](https://github.com/mozilla/mortar-privileged-remote-app/archive/master.zip). + + +## Usage + +Import the app into the [App Manager](https://developer.mozilla.org/Firefox_OS/Using_the_App_Manager). Then you can run it in the simulator, or in a Firefox OS device. + +## Code walkthrough + +The `manifest.webapp` file contains metadata about the app, such as its name, description, icon and required permissions for running under Firefox OS. Of particular interest for this app is the `systemXHR` permission, which is what enables us to load data from other domains, whether they have enabled CORS or not. + +Moving over to `index.html`, this is the starting point for the app when it's launched, and also where the layout is defined and the JavaScript files with the functionality and logic are loaded. + +The appearance is defined in `css/app.css`. There are just some very basic rules. + +We define the app's behaviour in `js/app.js`. The most important aspect of this app is how we run XMLHttpRequests across domains without getting same-origin or CORS errors, thanks to the usage of the `mozSystem: true` attribute when instancing the XMLHTTPRequests. Be sure to have a look at the code to see where this happens. + +Finally we are also including `js/libs/l10n.js`, which contains [L10n](https://developer.mozilla.org/en-US/docs/Web/API/L10n_API), a library for translating the strings in the app. Using this library, users can run the app in their own language, as long as you provide the translations for those languages. We're currently including a translation to Spanish as an example, but feel free to contribute with more translations in `data/locales.ini`, looking at `data/es.properties` and `data/en-US.properties` to see the syntax in action. The way it works, it will automatically translate the HTML elements that contain a `data-l10n-id` attribute with the translation identifier. + +For any dynamically shown content, you need to use the `navigator.webL10n.get` function, but since that is slightly tedious to write each time, we're aliasing it to just `translate`: + +```javascript +var translate = navigator.mozL10n.get; +``` + +## Getting help + +If you find something that doesn't quite work as you'd expect, we'd appreciate if you [filed a bug](https://github.com/mozilla/mortar-privileged-remote-app/issues)! + +We need your help in order to help you. Therefore: + +1. Tell us which version of the template are you using. Where did you get the code from? +* Specify the environment where the bug occurs i.e. which version of the Simulator or Firefox OS device. An example would be `1.2 simulator` or `Boot2Gecko 1.4.0.0`. +* Describe the problem in detail. What were you doing? What happened? What did you expect to happen? +* Probably also provide a test case so we can see what is happening and try to reproduce the error. + +Ultimately it all boils down to the fact that if we can't reproduce it, we can't help you or fix it either. + +## Contributing + +Contributions are always welcome! If you want to collaborate, whether that is with a new feature or fixing a bug, we recommend you... + +1. Have a look at the [issue tracker](https://github.com/mozilla/mortar-privileged-remote-app/issues) first--to make sure there isn't anyone working on that already. +* If it's a new issue/feature, or no one is working on it already, fork the project in GitHub (you'll need an account if you don't have it yet). +* Create the bug to let us know you want to work on this. That way we are aware of and can keep an eye on it, or maybe tell you that it is not a bug but an intended feature, and save you the hassle of working on something that is not needed. +* Clone your fork to your computer (i.e. get the code onto your computer) +* Make a new branch, and switch to that new branch +* Do the changes you deem necessary +* Push the branch to GitHub +* Send a pull request + +To make your changes as easy to merge back onto the project as possible, you should only work on one feature per branch. That makes code review simpler and faster! From 9d08cb80ffccc95473172be17013dbd222c9a152 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Sun, 14 Apr 2019 19:17:04 +0200 Subject: [PATCH 368/591] Revert "Created mortal (markdown)" Totally off topic for Git for Windows. This reverts commit dc658446b87abd837b2d1ae785a6f6c74690f6a6. Signed-off-by: Johannes Schindelin --- mortal.md | 68 ------------------------------------------------------- 1 file changed, 68 deletions(-) delete mode 100644 mortal.md diff --git a/mortal.md b/mortal.md deleted file mode 100644 index 1f7a687dc33da9..00000000000000 --- a/mortal.md +++ /dev/null @@ -1,68 +0,0 @@ -# Privileged remote app - -This is a privileged app template that demonstrates the usage of [`XMLHttpRequest`](https://developer.mozilla.org/docs/Web/API/XMLHttpRequest) and [`systemXHR`](https://developer.mozilla.org/Apps/Reference/Firefox_OS_device_APIs#systemXHR) to load remote content from a server, and includes a properly configured manifest file with the right app type (`privileged`) and required permissions, in order to use those APIs. - -This is part of the [mortar](https://github.com/mozilla/mortar/) template collection for building [Open Web Apps](https://developer.mozilla.org/Apps). - -## Obtaining - -There are a few ways to get this template: - -If you use [Git](http://www.git-scm.com/): - -````bash -git clone https://github.com/mozilla/mortar-privileged-remote-app.git -```` - -Or download the latest version in this [ZIP file](https://github.com/mozilla/mortar-privileged-remote-app/archive/master.zip). - - -## Usage - -Import the app into the [App Manager](https://developer.mozilla.org/Firefox_OS/Using_the_App_Manager). Then you can run it in the simulator, or in a Firefox OS device. - -## Code walkthrough - -The `manifest.webapp` file contains metadata about the app, such as its name, description, icon and required permissions for running under Firefox OS. Of particular interest for this app is the `systemXHR` permission, which is what enables us to load data from other domains, whether they have enabled CORS or not. - -Moving over to `index.html`, this is the starting point for the app when it's launched, and also where the layout is defined and the JavaScript files with the functionality and logic are loaded. - -The appearance is defined in `css/app.css`. There are just some very basic rules. - -We define the app's behaviour in `js/app.js`. The most important aspect of this app is how we run XMLHttpRequests across domains without getting same-origin or CORS errors, thanks to the usage of the `mozSystem: true` attribute when instancing the XMLHTTPRequests. Be sure to have a look at the code to see where this happens. - -Finally we are also including `js/libs/l10n.js`, which contains [L10n](https://developer.mozilla.org/en-US/docs/Web/API/L10n_API), a library for translating the strings in the app. Using this library, users can run the app in their own language, as long as you provide the translations for those languages. We're currently including a translation to Spanish as an example, but feel free to contribute with more translations in `data/locales.ini`, looking at `data/es.properties` and `data/en-US.properties` to see the syntax in action. The way it works, it will automatically translate the HTML elements that contain a `data-l10n-id` attribute with the translation identifier. - -For any dynamically shown content, you need to use the `navigator.webL10n.get` function, but since that is slightly tedious to write each time, we're aliasing it to just `translate`: - -```javascript -var translate = navigator.mozL10n.get; -``` - -## Getting help - -If you find something that doesn't quite work as you'd expect, we'd appreciate if you [filed a bug](https://github.com/mozilla/mortar-privileged-remote-app/issues)! - -We need your help in order to help you. Therefore: - -1. Tell us which version of the template are you using. Where did you get the code from? -* Specify the environment where the bug occurs i.e. which version of the Simulator or Firefox OS device. An example would be `1.2 simulator` or `Boot2Gecko 1.4.0.0`. -* Describe the problem in detail. What were you doing? What happened? What did you expect to happen? -* Probably also provide a test case so we can see what is happening and try to reproduce the error. - -Ultimately it all boils down to the fact that if we can't reproduce it, we can't help you or fix it either. - -## Contributing - -Contributions are always welcome! If you want to collaborate, whether that is with a new feature or fixing a bug, we recommend you... - -1. Have a look at the [issue tracker](https://github.com/mozilla/mortar-privileged-remote-app/issues) first--to make sure there isn't anyone working on that already. -* If it's a new issue/feature, or no one is working on it already, fork the project in GitHub (you'll need an account if you don't have it yet). -* Create the bug to let us know you want to work on this. That way we are aware of and can keep an eye on it, or maybe tell you that it is not a bug but an intended feature, and save you the hassle of working on something that is not needed. -* Clone your fork to your computer (i.e. get the code onto your computer) -* Make a new branch, and switch to that new branch -* Do the changes you deem necessary -* Push the branch to GitHub -* Send a pull request - -To make your changes as easy to merge back onto the project as possible, you should only work on one feature per branch. That makes code review simpler and faster! From 50f534382db2b8d70e7c4aed600ccdb238d5718c Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Tue, 4 Jun 2019 13:42:06 +0200 Subject: [PATCH 369/591] Touch up the "Starting the rebase" section, and add a "range-diff" one. --- Rebasing-Git-for-Windows.md | 44 +++++++++++++++++++++++++++++-------- 1 file changed, 35 insertions(+), 9 deletions(-) diff --git a/Rebasing-Git-for-Windows.md b/Rebasing-Git-for-Windows.md index 2bbf3732174a1c..50b6e744ad6db1 100644 --- a/Rebasing-Git-for-Windows.md +++ b/Rebasing-Git-for-Windows.md @@ -20,18 +20,17 @@ To do a *rebase* of the *Git for Windows* source onto a new [upstream](https://g `git fetch git` # Starting the *rebase* -1. Find the commit of the last *rebase* and remember it. - `BASE="$(git rev-parse ":/Start the merging-rebase")"` or possibly - `BASE="$(git rev-parse HEAD^{"/Start the merging-rebase}")"` if there have been - trial merging rebases on other branches. Check with - `git log -1 $BASE` and `git branch -a --contains $BASE`. -2. Run the `shears.sh` script to build up the actual *rebase* script. - `../build-extra/./shears.sh --merging --onto v2.3.4 $BASE` +Run the `shears.sh` script to build up the actual *rebase* script. + `/usr/src/build-extra/shears.sh --merging --onto v2.3.4 merging-rebase` Note: `v2.3.4` is a `tag` in the remote `git`. See the script if you are testing changes initiated in a local branch of the git upstream. -3. The *rebase* should start automatically and occasionally stop if it hits any merge conflicts. Resolve those conflicts (see also [Merge Conflicts Resolving and Remembering them](https://github.com/git-for-windows/git/wiki/Merge-Conflicts---Resolving-and-Remembering-them)) and then continue the rebase. + +The *rebase* should start automatically and occasionally stop if it hits any merge conflicts. Resolve those conflicts (see also [Merge Conflicts Resolving and Remembering them](https://github.com/git-for-windows/git/wiki/Merge-Conflicts---Resolving-and-Remembering-them)) and then continue the rebase. `git rebase --continue` +Note: the `merging-rebase` argument is a special placeholder that is interpreted by the `shears.sh` script to find the commit that started the previous merging-rebase. You can find the commit yourself like this: + `BASE="$(git rev-parse HEAD^{/^"Start the merging-rebase"})"` + # Verifying the *rebase* 1. Generate a *diff* of the previous state. `git diff v2.3.3..origin/master > prev.diff` @@ -46,4 +45,31 @@ To do a *rebase* of the *Git for Windows* source onto a new [upstream](https://g >When there is a line that starts with a `-` or a `+` but then continues with a space, that's good! >It means that the context of our changes changed. -The newer `git range-diff` may also be used. +In addition to that, you can also use the `range-diff` command to verify the rebase: + +```sh +r=^{/^Start.the.merging-rebase} +git range-diff HEAD$r^2$r..HEAD$r^2 HEAD$r.. +``` + +## Explanation + +`HEAD^{/^Start.the.merging-rebase}` (abbreviated in the example as `HEAD$r`) finds the latest commit which started a merging-rebase and which is reachable from `HEAD`. + +That commit is a "fake" merge, i.e. it merges the pre-rebase commit history, but leaves the tree identical compared to the state before the merge. That is, its first parent is the commit onto which the patches were rebased, and its second parent is the tip of the patches that were rebased. + +As such, `HEAD$r^2` refers to the tip of the pre-rebase commits, and `HEAD$r^2$r` to the bottom of the rebased commits (pre-rebase). Ergo: `HEAD$r^2$r..HEAD$r^2` specifies the commits *before* the rebase. + +Likewise, `HEAD$r` refers to the bottom of the rebased commits (post-rebase), and `HEAD` is obviously the tip of those commits. That is, `HEAD$r..` specifies the commits *after* the rebase. + +## How to read the output of the `range-diff` +Note that the output of the range-diff can be a bit daunting to read: it is a diff between diffs. As such, there are "outer" diff markers (`-`/`+`), denoting differences between the compared commit ranges, and "inner" diff markers which correspond to the patches of the individual commits instead. + +To verify that everything worked as intended, you need to watch out for lines that start with *two* diff markers: those indicate that the pre-rebase and post-rebase commits modify the code in *different* ways. + +The output is color-coded in two levels: the familiar green/red (as in `git diff`'s output) corresponds to added/removed lines. The second level is dim/bright: if green/red lines are dim, that indicates that this is the pre-rebase version of the patch; conversely, any bright green/red lines indicate post-rebase versions. + +More notes on reading the output of this `range-diff` command: +- It is quite common that the context changes, e.g. when a new `#include` line was introduced both in the rebased patch as well as upstream (in which case, the upstream line would be marked with an outer diff marker, but the line itself would be uncolored because it is in the context of the post-rebase version of the patch). +- When whole commits are marked in red, they have been dropped during the rebase. This is quite normal when patches were "upstreamed". +- Sometimes, commits are marked in red, as if they were removed, but there are also green lines that "re-introduce" them. That happens when `range-diff` fails to detect that the pre-rebase and post-rebase versions of the commit correspond to one another. This can be fixed by passing a `--creation-factor` to the `range-diff` command (sensible values are between 60, the default, and 100). \ No newline at end of file From fd7e5b0acf76379a340a7d9a7de302893c19379f Mon Sep 17 00:00:00 2001 From: Sheryl Hohman Date: Tue, 23 Jul 2019 11:15:59 -0700 Subject: [PATCH 370/591] minor typos/grammar (eg missing word: `be`) --- Technical-overview.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/Technical-overview.md b/Technical-overview.md index 8a789af2c7e9cf..d9f2e7ce474291 100644 --- a/Technical-overview.md +++ b/Technical-overview.md @@ -1,6 +1,6 @@ The process to build installer is made easy via the `Git for Windows SDK`. The steps are basically: -1. Download and install the SDK, which installs the sources for `git`, additional msys and mingw packages and helpers to build the installer and provides the `Git for Windows SDK` MSys shell +1. Download and install the SDK, which installs the sources for `git`, additional msys and mingw packages, and helpers to build the installer. It also provides the `Git for Windows SDK` MSys shell 2. [optional] Hack in the changes you want and make these changes available to the installer. 3. Call the right helper tools to build the package you want. @@ -22,7 +22,7 @@ Afterwards you need to install git to make these changes available to the instal If you made any documentation changes, you need to install the documentation too: `make install-html && prefix=/mingw64 make -C contrib/subtree install-html` (the second make invocation installs the `git-subtree.html` which is otherwise missing and leads to an error by the portable installer). -In some cases the change you want to make is not in git itself but in the additional files needed to emulate the *ix environment git expects (things like `grep`, `find`, `cat`,...) or in additional helper files (e.g. `start-ssh-agent.cmd`). These files come from [Msys](https://github.com/git-for-windows/MSYS2-packages) and [Mingw](https://github.com/git-for-windows/MINGW-packages) packages. Please see the documentation how to make [changes to these packages](Package-management#technical-details). Some files are also in the `build-extras` repo in the subdir [`git-extra`](https://github.com/git-for-windows/build-extra/tree/master/git-extra) (the script which calls notepad as a commit message editor, diff filter for word files,...). The source code for these files are also under `/usr/src` but need to checked out first (e.g. `cd /usr/src/MINGW-packages && git fetch && git checkout master`). +In some cases, the change you want to make is not in git itself, but in the additional files needed to emulate the *ix environment git expects (things like `grep`, `find`, `cat`,...), or in additional helper files (e.g. `start-ssh-agent.cmd`). These files come from [Msys](https://github.com/git-for-windows/MSYS2-packages) and [Mingw](https://github.com/git-for-windows/MINGW-packages) packages. Please see the documentation for how to make [changes to these packages](Package-management#technical-details). Some files are also in the `build-extras` repo in the subdir [`git-extra`](https://github.com/git-for-windows/build-extra/tree/master/git-extra) (the script which calls notepad as a commit message editor, diff filter for word files,...). The source code for these files are also under `/usr/src` but need to be checked out first (e.g. `cd /usr/src/MINGW-packages && git fetch && git checkout master`). # Building an installer From 1c80776c0a9752efe0e573f4787059b6185b5e7a Mon Sep 17 00:00:00 2001 From: Sheryl Hohman Date: Tue, 23 Jul 2019 11:18:30 -0700 Subject: [PATCH 371/591] link to the anchor mentioned --- Technical-overview.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Technical-overview.md b/Technical-overview.md index d9f2e7ce474291..42c9eef254703f 100644 --- a/Technical-overview.md +++ b/Technical-overview.md @@ -28,7 +28,7 @@ In some cases, the change you want to make is not in git itself, but in the addi You can build both a normal setup installer and a portable one. -The installers are basically created by collecting files from the `Git for Windows SDK` Msys environment, not from any checked out source code! It's therefore important to make any changed files available to the installer (the `make` calls in the "Hacking on git" step)! +The installers are basically created by collecting files from the `Git for Windows SDK` Msys environment, not from any checked out source code! It's therefore important to make any changed files available to the installer (the `make` calls in the "[Hacking on git](https://github.com/git-for-windows/git/wiki/Technical-overview#hacking-on-git)" step)! As a one time step, you need to prepare the extra files which contain the helper scripts: From 0f2f5c9e825cdbfb885b89522e86bb08bbe86123 Mon Sep 17 00:00:00 2001 From: Clemens Buchacher Date: Thu, 25 Jul 2019 22:04:34 +0200 Subject: [PATCH 372/591] Add a section on directory junctions --- Symbolic-Links.md | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/Symbolic-Links.md b/Symbolic-Links.md index 80d7c13b78805d..d748e8d5a9f95d 100644 --- a/Symbolic-Links.md +++ b/Symbolic-Links.md @@ -38,4 +38,12 @@ The privilege of `Create symbolic links` can be assigned using local policy edit - Polsedit: Launch `polseditx32.exe` or `polseditx64.exe` (depending on your Windows version), navigate to `Security Settings - User Rights Assignment` and add the account(s) to the list named `Create symbolic links`. -Note that regardless of privilege assignment, members of the Administrators group will also require UAC elevation (see the full details in the *Access Token Changes* section in this [document on UAC](https://msdn.microsoft.com/en-us/library/bb530410.aspx)). Since Windows 10 version 1703 (*Creators Update*), [enabling Developer Mode](https://docs.microsoft.com/en-us/windows/uwp/get-started/enable-your-device-for-development) will disable this restriction and [allow creating symlinks without UAC elevation](https://blogs.windows.com/buildingapps/2016/12/02/symlinks-windows-10/) (although Git for Windows still requires UAC elevation up to and including v2.13.0). \ No newline at end of file +Note that regardless of privilege assignment, members of the Administrators group will also require UAC elevation (see the full details in the *Access Token Changes* section in this [document on UAC](https://msdn.microsoft.com/en-us/library/bb530410.aspx)). Since Windows 10 version 1703 (*Creators Update*), [enabling Developer Mode](https://docs.microsoft.com/en-us/windows/uwp/get-started/enable-your-device-for-development) will disable this restriction and [allow creating symlinks without UAC elevation](https://blogs.windows.com/buildingapps/2016/12/02/symlinks-windows-10/) (although Git for Windows still requires UAC elevation up to and including v2.13.0). + +# Creating directory junctions + +Directory junctions can be created by non-administrator users by default. Therefore, they are a popular alternative to symbolic links. To create a directory junction, use the `mklink` command with the `/j` option: + +```cmd +mklink /j this-link-points-to c:\that-directory +``` \ No newline at end of file From 39c92f4089624304bbc7615584e28c5b0422ecb2 Mon Sep 17 00:00:00 2001 From: leandrovitor Date: Thu, 8 Aug 2019 03:01:38 +0000 Subject: [PATCH 373/591] tyty --- pagina.asciidoc | 1 + 1 file changed, 1 insertion(+) create mode 100644 pagina.asciidoc diff --git a/pagina.asciidoc b/pagina.asciidoc new file mode 100644 index 00000000000000..cd2926cf7bc06b --- /dev/null +++ b/pagina.asciidoc @@ -0,0 +1 @@ +tytytyty \ No newline at end of file From cfc5eea2fb6a346809fbebd2da8c0d3394051d0b Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Thu, 8 Aug 2019 07:51:37 +0200 Subject: [PATCH 374/591] Destroyed pagina (asciidoc) --- pagina.asciidoc | 1 - 1 file changed, 1 deletion(-) delete mode 100644 pagina.asciidoc diff --git a/pagina.asciidoc b/pagina.asciidoc deleted file mode 100644 index cd2926cf7bc06b..00000000000000 --- a/pagina.asciidoc +++ /dev/null @@ -1 +0,0 @@ -tytytyty \ No newline at end of file From dad621a4cb863856af398e147e0e5db7694f562d Mon Sep 17 00:00:00 2001 From: Oliver Schneider Date: Tue, 27 Aug 2019 23:56:29 +0200 Subject: [PATCH 375/591] Replaced link to version-specific raw version of document with link to specific (named) anchor in canonical location for that (rendered) page ... --- How-to-participate.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/How-to-participate.md b/How-to-participate.md index 6e32e63237271e..3321fad5557b09 100644 --- a/How-to-participate.md +++ b/How-to-participate.md @@ -15,7 +15,7 @@ Download [the SDK](https://gitforwindows.org/#download-sdk) and build Git. See t Also have a look at [this page](https://github.com/git-for-windows/git/wiki/Building-Git) for tips and tricks revolving around building and debugging Git. -Please also sign off your work, as [asked by the Git project](https://github.com/git/git/blob/v2.3.5/Documentation/SubmittingPatches#L234-L286) +Please also sign off your work, as [asked by the Git project](https://git-scm.com/docs/SubmittingPatches#sign-off) After that, submit a Pull Request. From 8247c1b147c0335f83a89c2a901af441ba958dd6 Mon Sep 17 00:00:00 2001 From: inspector71 Date: Mon, 9 Sep 2019 02:50:01 +0000 Subject: [PATCH 376/591] Improve opening paragraph --- Technical-overview.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Technical-overview.md b/Technical-overview.md index 42c9eef254703f..18f6a4235ddd40 100644 --- a/Technical-overview.md +++ b/Technical-overview.md @@ -1,4 +1,4 @@ -The process to build installer is made easy via the `Git for Windows SDK`. The steps are basically: +The process to build an instance of the Git for Windows installer is made easier with the `Git for Windows SDK`. Basically, the steps are as follows: 1. Download and install the SDK, which installs the sources for `git`, additional msys and mingw packages, and helpers to build the installer. It also provides the `Git for Windows SDK` MSys shell 2. [optional] Hack in the changes you want and make these changes available to the installer. From 969aae5386c950da24b3a56254fad49d2e107442 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Fri, 13 Sep 2019 13:29:54 +0200 Subject: [PATCH 377/591] Rephrase the sentence about versions that fixed bugs, to avoid confusion whether those versions actually introduced bugs rather than fixing them --- FAQ.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/FAQ.md b/FAQ.md index 5060e1a0c810f7..f6f525c33ba50f 100644 --- a/FAQ.md +++ b/FAQ.md @@ -27,7 +27,7 @@ In the meantime you could try: In general, yes: it is a good idea to stay up-to-date. -If you have a version older than 2.17.1(2), it is *highly* advisable to upgrade. These versions fixed critical bugs, therefore sticking with older Git for Windows versions makes you vulnerable: 2.17.1(2), 2.14.1, 2.7.4, 2.7.0, 2.6.1, 2.5.2, 1.9.5-preview20150319, and 1.9.5-preview20141217. +If you have a version older than 2.17.1(2), it is *highly* advisable to upgrade. A couple of Git versions came with important fixes to security-relevant vulnerabilities: 2.17.1(2), 2.14.1, 2.7.4, 2.7.0, 2.6.1, 2.5.2, 1.9.5-preview20150319, and 1.9.5-preview20141217. ## What is the release cadence of Git for Windows? From 639d64e216db27b3dfb27b860333b5be5988bda5 Mon Sep 17 00:00:00 2001 From: lxy <391861737@qq.com> Date: Wed, 6 Nov 2019 17:07:39 +0800 Subject: [PATCH 378/591] Created Install or update inside Msys2, Cygwin or Git-for-windows itself (markdown) --- ...e-inside-Msys2,-Cygwin-or-Git-for-windows-itself.md | 10 ++++++++++ 1 file changed, 10 insertions(+) create mode 100644 Install-or-update-inside-Msys2,-Cygwin-or-Git-for-windows-itself.md diff --git a/Install-or-update-inside-Msys2,-Cygwin-or-Git-for-windows-itself.md b/Install-or-update-inside-Msys2,-Cygwin-or-Git-for-windows-itself.md new file mode 100644 index 00000000000000..b6f2e12c7101a7 --- /dev/null +++ b/Install-or-update-inside-Msys2,-Cygwin-or-Git-for-windows-itself.md @@ -0,0 +1,10 @@ +## It's different from [Install inside MSYS2 proper](https://github.com/git-for-windows/git/wiki/Install-inside-MSYS2-proper) + +Instead of configuring and installing `Git-for-windows` using `Pacman`, this guide introduces another approach to properly install or update `git-for-windows` inside `Msys2`, `Cygwin` or even `Git-for-windows` itself. The only thing you need is a `bash` interpreter on windows and a `curl`. + +With the script `getgit` introduced by [git-for-windows/build-extra#261](https://github.com/git-for-windows/build-extra/pull/261), you can download and run the script or just run `curl https://raw.githubusercontent.com/git-for-windows/build-extra/gitupdate/git-extra/getgit | bash`. + +The script would gather information about the current system ( *Msys / Cygwin* ), bitness, version of an already existed git-for-windows, version of the latest released git-for-windows... and then forge a proper download URL targeting a proper version of the `PortableGit` installer. +With all the information prepared, the script would download the installer and unpack it to `/tmp`. After that, all the necessary files will be copied to a proper place inside the ( *Msys's / Cygwin's* ) file system without touching any existing **non-git-for-windows-exclusive** files. + +Additionally, the `getgit` script will produce two scripts `ctxmenu.bat` and `rm-ctxmenu.bat` which could add and remove `Git GUI Here` and `Git Bash Here` context menu items. But note that, these two context menu items although seem alike with the ones of `Git-for-windows`, they are actually **different**! They just provided similar outcomes and functionality yet still not the same things. \ No newline at end of file From 079969d78fe57d313320951a51805e81da6de3d5 Mon Sep 17 00:00:00 2001 From: lxy <391861737@qq.com> Date: Wed, 6 Nov 2019 17:08:17 +0800 Subject: [PATCH 379/591] Updated Install or update inside Msys2, Cygwin or Git for windows itself (markdown) --- ...-or-update-inside-Msys2,-Cygwin-or-Git-for-windows-itself.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/Install-or-update-inside-Msys2,-Cygwin-or-Git-for-windows-itself.md b/Install-or-update-inside-Msys2,-Cygwin-or-Git-for-windows-itself.md index b6f2e12c7101a7..ae513fd67cbd5e 100644 --- a/Install-or-update-inside-Msys2,-Cygwin-or-Git-for-windows-itself.md +++ b/Install-or-update-inside-Msys2,-Cygwin-or-Git-for-windows-itself.md @@ -2,6 +2,8 @@ Instead of configuring and installing `Git-for-windows` using `Pacman`, this guide introduces another approach to properly install or update `git-for-windows` inside `Msys2`, `Cygwin` or even `Git-for-windows` itself. The only thing you need is a `bash` interpreter on windows and a `curl`. +## How to + With the script `getgit` introduced by [git-for-windows/build-extra#261](https://github.com/git-for-windows/build-extra/pull/261), you can download and run the script or just run `curl https://raw.githubusercontent.com/git-for-windows/build-extra/gitupdate/git-extra/getgit | bash`. The script would gather information about the current system ( *Msys / Cygwin* ), bitness, version of an already existed git-for-windows, version of the latest released git-for-windows... and then forge a proper download URL targeting a proper version of the `PortableGit` installer. From 4742b1a039421e5d10d0d4648686eb8f7c347561 Mon Sep 17 00:00:00 2001 From: lxy <391861737@qq.com> Date: Wed, 6 Nov 2019 17:43:45 +0800 Subject: [PATCH 380/591] Updated Install or update inside Msys2, Cygwin or Git for windows itself (markdown) --- ...-update-inside-Msys2,-Cygwin-or-Git-for-windows-itself.md | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/Install-or-update-inside-Msys2,-Cygwin-or-Git-for-windows-itself.md b/Install-or-update-inside-Msys2,-Cygwin-or-Git-for-windows-itself.md index ae513fd67cbd5e..63f114314c1e67 100644 --- a/Install-or-update-inside-Msys2,-Cygwin-or-Git-for-windows-itself.md +++ b/Install-or-update-inside-Msys2,-Cygwin-or-Git-for-windows-itself.md @@ -9,4 +9,7 @@ With the script `getgit` introduced by [git-for-windows/build-extra#261](https:/ The script would gather information about the current system ( *Msys / Cygwin* ), bitness, version of an already existed git-for-windows, version of the latest released git-for-windows... and then forge a proper download URL targeting a proper version of the `PortableGit` installer. With all the information prepared, the script would download the installer and unpack it to `/tmp`. After that, all the necessary files will be copied to a proper place inside the ( *Msys's / Cygwin's* ) file system without touching any existing **non-git-for-windows-exclusive** files. -Additionally, the `getgit` script will produce two scripts `ctxmenu.bat` and `rm-ctxmenu.bat` which could add and remove `Git GUI Here` and `Git Bash Here` context menu items. But note that, these two context menu items although seem alike with the ones of `Git-for-windows`, they are actually **different**! They just provided similar outcomes and functionality yet still not the same things. \ No newline at end of file +Additionally, the `getgit` script will produce two scripts `ctxmenu.bat` and `rm-ctxmenu.bat` which could add and remove `Git GUI Here` and `Git Bash Here` context menu items. But note that, these two context menu items although seem alike with the ones of `Git-for-windows`, they are actually **different**! They just provided similar outcomes and functionality yet still not the same things. + +## Known issue +On Cygwin, the final `Git Bash Here` won't have a nice prompt that has the current branch of a git repo folder shown. To fix this, you need to remove the `PS1=...` line in the `/etc/bash.bashrc`. \ No newline at end of file From e82b64f1b43eaedde06951c65a6a22f40493f8f2 Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Wed, 6 Nov 2019 11:01:42 +0000 Subject: [PATCH 381/591] added new page index --- 0.-Index.md | 1 + 1 file changed, 1 insertion(+) diff --git a/0.-Index.md b/0.-Index.md index 9cf0a6cf620d2c..9013151260bf30 100644 --- a/0.-Index.md +++ b/0.-Index.md @@ -18,6 +18,7 @@ This is for the poor souls in corporate IE environments who can't expand the pag * [Good commits](https://github.com/git-for-windows/git/wiki/Good-commits) * [How to participate](https://github.com/git-for-windows/git/wiki/How-to-participate) * [Install inside MSYS2 proper](https://github.com/git-for-windows/git/wiki/Install-inside-MSYS2-proper) +* [Install or update inside Msys2, Cygwin or Git-for-windows itself](https://github.com/git-for-windows/git/wiki/Install-or-update-inside-Msys2,-Cygwin-or-Git-for-windows-itself) * [Issue reporting guidelines](https://github.com/git-for-windows/git/wiki/Issue-reporting-guidelines) * [Making a portable Git](https://github.com/git-for-windows/git/wiki/Making-a-portable-Git) * [Making an installer](https://github.com/git-for-windows/git/wiki/Making-an-installer) From 5a632e70412adce653f554b1083fcd4be6a0c777 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Wed, 6 Nov 2019 20:50:39 +0100 Subject: [PATCH 382/591] Use MSYS2 instead of Msys2 There seems to be a strong preference by the MSYS2 project to have it in all-capital letters. Signed-off-by: Johannes Schindelin --- 0.-Index.md | 2 +- ...r-update-inside-MSYS2,-Cygwin-or-Git-for-windows-itself.md | 4 ++-- Updating-your-SDK.md | 2 +- 3 files changed, 4 insertions(+), 4 deletions(-) rename Install-or-update-inside-Msys2,-Cygwin-or-Git-for-windows-itself.md => Install-or-update-inside-MSYS2,-Cygwin-or-Git-for-windows-itself.md (96%) diff --git a/0.-Index.md b/0.-Index.md index 9013151260bf30..3077da140eddfa 100644 --- a/0.-Index.md +++ b/0.-Index.md @@ -18,7 +18,7 @@ This is for the poor souls in corporate IE environments who can't expand the pag * [Good commits](https://github.com/git-for-windows/git/wiki/Good-commits) * [How to participate](https://github.com/git-for-windows/git/wiki/How-to-participate) * [Install inside MSYS2 proper](https://github.com/git-for-windows/git/wiki/Install-inside-MSYS2-proper) -* [Install or update inside Msys2, Cygwin or Git-for-windows itself](https://github.com/git-for-windows/git/wiki/Install-or-update-inside-Msys2,-Cygwin-or-Git-for-windows-itself) +* [Install or update inside MSYS2, Cygwin or Git-for-windows itself](https://github.com/git-for-windows/git/wiki/Install-or-update-inside-MSYS2,-Cygwin-or-Git-for-windows-itself) * [Issue reporting guidelines](https://github.com/git-for-windows/git/wiki/Issue-reporting-guidelines) * [Making a portable Git](https://github.com/git-for-windows/git/wiki/Making-a-portable-Git) * [Making an installer](https://github.com/git-for-windows/git/wiki/Making-an-installer) diff --git a/Install-or-update-inside-Msys2,-Cygwin-or-Git-for-windows-itself.md b/Install-or-update-inside-MSYS2,-Cygwin-or-Git-for-windows-itself.md similarity index 96% rename from Install-or-update-inside-Msys2,-Cygwin-or-Git-for-windows-itself.md rename to Install-or-update-inside-MSYS2,-Cygwin-or-Git-for-windows-itself.md index 63f114314c1e67..8707b74d60853e 100644 --- a/Install-or-update-inside-Msys2,-Cygwin-or-Git-for-windows-itself.md +++ b/Install-or-update-inside-MSYS2,-Cygwin-or-Git-for-windows-itself.md @@ -1,6 +1,6 @@ ## It's different from [Install inside MSYS2 proper](https://github.com/git-for-windows/git/wiki/Install-inside-MSYS2-proper) -Instead of configuring and installing `Git-for-windows` using `Pacman`, this guide introduces another approach to properly install or update `git-for-windows` inside `Msys2`, `Cygwin` or even `Git-for-windows` itself. The only thing you need is a `bash` interpreter on windows and a `curl`. +Instead of configuring and installing `Git-for-windows` using `Pacman`, this guide introduces another approach to properly install or update `git-for-windows` inside `MSYS2`, `Cygwin` or even `Git-for-windows` itself. The only thing you need is a `bash` interpreter on windows and a `curl`. ## How to @@ -12,4 +12,4 @@ With all the information prepared, the script would download the installer and u Additionally, the `getgit` script will produce two scripts `ctxmenu.bat` and `rm-ctxmenu.bat` which could add and remove `Git GUI Here` and `Git Bash Here` context menu items. But note that, these two context menu items although seem alike with the ones of `Git-for-windows`, they are actually **different**! They just provided similar outcomes and functionality yet still not the same things. ## Known issue -On Cygwin, the final `Git Bash Here` won't have a nice prompt that has the current branch of a git repo folder shown. To fix this, you need to remove the `PS1=...` line in the `/etc/bash.bashrc`. \ No newline at end of file +On Cygwin, the final `Git Bash Here` won't have a nice prompt that has the current branch of a git repo folder shown. To fix this, you need to remove the `PS1=...` line in the `/etc/bash.bashrc`. diff --git a/Updating-your-SDK.md b/Updating-your-SDK.md index d6d8359c9ed340..d8073488f5d9e2 100644 --- a/Updating-your-SDK.md +++ b/Updating-your-SDK.md @@ -4,7 +4,7 @@ The [Git for Windows SDK release](https://github.com/git-for-windows/build-extra This was previously called the 'net installer', see below. It provides everything required to bootstrap a development environment, even if no git is available (or a unstable one is being worked on). -It is also possible to manually extract the archive and then run `./setup-git-sdk.bat` in the Msys2 terminal window. +It is also possible to manually extract the archive and then run `./setup-git-sdk.bat` in the MSYS2 terminal window. Alternatively, you can also clone your own copy of the 64 bit SDK with `git clone --depth=1 https://github.com/git-for-windows/git-sdk-64` (or `...-32` for 32-bit)... (select depth to taste) (See #816). The repository contains exes and DLLS so you should run the rebase script for the 32 bit version. From bd1a7630c9cea949bdf4f6720ec1890029a6fac2 Mon Sep 17 00:00:00 2001 From: lxy <391861737@qq.com> Date: Fri, 8 Nov 2019 16:53:29 +0800 Subject: [PATCH 383/591] Updated Install or update inside MSYS2, Cygwin or Git for windows itself (markdown) --- ...or-update-inside-MSYS2,-Cygwin-or-Git-for-windows-itself.md | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/Install-or-update-inside-MSYS2,-Cygwin-or-Git-for-windows-itself.md b/Install-or-update-inside-MSYS2,-Cygwin-or-Git-for-windows-itself.md index 8707b74d60853e..820e1e955b7651 100644 --- a/Install-or-update-inside-MSYS2,-Cygwin-or-Git-for-windows-itself.md +++ b/Install-or-update-inside-MSYS2,-Cygwin-or-Git-for-windows-itself.md @@ -12,4 +12,5 @@ With all the information prepared, the script would download the installer and u Additionally, the `getgit` script will produce two scripts `ctxmenu.bat` and `rm-ctxmenu.bat` which could add and remove `Git GUI Here` and `Git Bash Here` context menu items. But note that, these two context menu items although seem alike with the ones of `Git-for-windows`, they are actually **different**! They just provided similar outcomes and functionality yet still not the same things. ## Known issue -On Cygwin, the final `Git Bash Here` won't have a nice prompt that has the current branch of a git repo folder shown. To fix this, you need to remove the `PS1=...` line in the `/etc/bash.bashrc`. +* On Cygwin, the final `Git Bash Here` won't have a nice prompt that has the current branch of a git repo folder shown. To fix this, you need to remove the `PS1=...` line in the `/etc/bash.bashrc`. +* If some `Permission denied` errors raised, please run your `bash` as Administrator to make sure this script runs with write privilege granted. And if something similar happens against `ctxmenu.bat` script or `rm-ctxmenu.bat`, run it as **Administrator** as well. From 14ec52ec68fab51db5e7fe95c96d503af3793aa6 Mon Sep 17 00:00:00 2001 From: David Macek Date: Sat, 9 Nov 2019 15:44:06 +0100 Subject: [PATCH 384/591] Fix factual mistakes, explain more some bits --- ...ec(),-CreateProcess():-Windows-vs-Linux.md | 34 ++++++------------- 1 file changed, 10 insertions(+), 24 deletions(-) diff --git a/fork(),-exec(),-CreateProcess():-Windows-vs-Linux.md b/fork(),-exec(),-CreateProcess():-Windows-vs-Linux.md index ac9243f330ede8..4a2d5ff294c217 100644 --- a/fork(),-exec(),-CreateProcess():-Windows-vs-Linux.md +++ b/fork(),-exec(),-CreateProcess():-Windows-vs-Linux.md @@ -1,40 +1,26 @@ -# tl ; dr +# TL;DR -You need to make 2 calls to create new process in Linux: [`fork()`](http://man7.org/linux/man-pages/man2/fork.2.html) and then [`exec()`](http://man7.org/linux/man-pages/man3/exec.3.html). Windows has only one: [`CreateProcess()`](https://msdn.microsoft.com/en-us/library/windows/desktop/ms682425(v=vs.85).aspx). Architecture differs so much, that's why it was so hard to implement `fork()` on Windows, and it still works dramatically slower. Please think twice before using `fork()` on Windows, and do not use `fork()` + `exec()`: you are doing tons of useless job, you have `CreateProcess()` for it. +Traditionally, you needed to make 2 separate calls to create new process in Linux: [`fork()`](http://man7.org/linux/man-pages/man2/fork.2.html) and then [`exec()`](http://man7.org/linux/man-pages/man3/exec.3.html). Windows has a different way, using a single call ([`CreateProcess()`](https://msdn.microsoft.com/en-us/library/windows/desktop/ms682425(v=vs.85).aspx)), and doesn't support `fork()`. Software originally written for Linux has to use an emulated (way slower and somewhat imperfect) `fork()` to run on Windows. If this software creates a lot of processes during its normal workload, it will then run noticeably slower on Windows than on Linux. + +Note that there's a newer, single call method on Linux ([`posix_spawn()`](http://man7.org/linux/man-pages/man3/posix_spawn.3.html)) that should have better performance when ported to Windows. ## Before start All information about Linux is a brief retelling of Robert Love's book: [Linux Kernel Development](https://doc.lagout.org/operating%20system%20/linux/Linux%20Kernel%20Development%2C%203rd%20Edition.pdf). -I definitely recommend to read this book by yourself, especially if this article wasn't enough for you. I will oversimplify, otherwise I need to put whole book here. - -`fork()` on Windows is emulated by MSYS, while there is no `fork()` in MINGW. That is partially what makes [MSYS much slower than MINGW](https://github.com/git-for-windows/git/wiki/The-difference-between-MINGW-and-MSYS2). - -# Process vs thread +I definitely recommend you to read this book by yourself, especially if this article wasn't enough for you. I will oversimplify, otherwise I'd need to put the whole book here. -In Windows, process is a container for threads, while thread is an executing instance of program with corresponding resources. Process can have any number of threads that you want. 0 threads is possible, but useless; many threads give an opportunity to make multithreading application. All threads in one process share same piece of memory and need to use synchronisation mechanisms. - -In Linux, there is no difference between process and thread. They use virtual processor (it's exclusive for each process/thread) and virtual memory (it's shared). Virtual processor gives an illusion that every process/thread has its own real processor for all its needs, while in fact they use the processor by turns. Virtual memory also gives an illusion that process/thread has all available memory in the system (shared with other connected processes/threads), while in fact it's just a piece of memory for this group. +`fork()` on Windows is emulated by *MSYS*, while there is no `fork()` in *MINGW*. That is partially what makes [MSYS much slower than MINGW](https://github.com/git-for-windows/git/wiki/The-difference-between-MINGW-and-MSYS2). # Copy-on-write -COW is a general mechanism that allows avoiding copying while we do not need it. It's easier to explain this awesome mechanism with example from life. Imagine you have a great paper book, and your friends want to read it with you. Moreover, all of you want to make notes while reading. Naive solution is to make N full copies of the book for all readers, and then read each copy and make notes. But COW offers you to read the same book, and make the notes in your own notebook: you can copy little pieces if you want, but you don't need to make full copy. So, every reader owns the notebook, but you have only 1 book for all: it is enough. It allows to save time dramatically. +COW is a general mechanism that allows avoiding copying while we do not need it. It's easier to explain this awesome mechanism with an example from life. Imagine you have a great paper book, and your friends want to read it with you. Moreover, all of you want to make notes while reading. The naive solution is to make a full copy of the book for each reader, and then read each copy and make notes. But COW offers you to read the same book, and make the notes in your own notebook: you can copy little pieces if you want, but you don't need to make a full copy. So, every reader owns the notebook, but you have only 1 book for all: it is enough. It allows to save time dramatically. # Linux internals: fork(), exec() -`fork()` creates new process from existing one using COW. So, `fork()` makes a copy of the process, but you need to understand that there is almost no copying at all because of COW. - -`exec()` puts the executable into new process and starts to execute it. +`fork()` creates new process as an almost identical copy of an existing one. `exec()` loads another executable into the new process and starts to execute it instead of the copied executable. In the end, the original process continues as before and there's a new, different process running. -Is is super important moment: we do not only save time by COW; we save it in high-loaded moment. Everyone wants to start their new task immediately, without any waiting. Additionally, there is a big chance that we will never copy all this parent's stuff: it's a common scenario when we do not need it at all. +Since this scenario is so common on Linux, the system is optimized to execute `fork()` very quickly. In theory, it makes a copy of the process, but there is almost no actual copying yet thanks to COW. Calling `exec()` then throws out all this would-be-copied stuff and no time is wasted. # Windows internals: why fork() does not work as native -Actually, we have enough information to guess the reason. - -At first, process on Windows and on Linux means different things: we need to create both process and at least one thread to start executing smth on Windows. COW can't be done without headache because of different ways of working with memory. We also have tons of other problems that are behind the scene for this article. - -In short, *All* programs linking to the [MSYS2 runtime](https://github.com/git-for-windows/git/wiki/The-difference-between-MINGW-and-MSYS2) essentially perform the check "was I just forked?" at startup. If that is the case, the regular code path is completely disabled and a special "fork mode" is spun up. - -As a result, it really copies the entire address accessible space of the original process. It tries as best as it can to open the original file descriptors and sockets. It reinstates the current working directory (even if it does not exist anymore). And it does this and that, and that and this, and basically spends a whole lot of time that Linux' kernel would give the programs for free. - -All of this was useless if you use `exec()` after it. You have `CreateProcess()` that was created as a part of Windows platform, and it is optimized to be fast enough. \ No newline at end of file +Windows doesn't officially have a good substitute of neither `fork()` nor `exec()`, so some smart people made a replacement that works pretty well, but can't be optimized well because it doesn't work at the system level. The replacement works like this: By calling `fork()`, the original process creates a process from the same executable, but it's like brand new at this point, as if it had no connection to the original one. Then the new process realizes it is supposed to be a fork and copies the entire address accessible memory space of the original process. It tries as best as it can to open the original file descriptors and sockets. It reinstates the current working directory (even if it does not exist anymore) and more. It spends a whole lot of time making sure the fork is as perfect as it can be [and may even fail completely when it can't due to DLL preloading](https://github.com/git-for-windows/git/wiki/32-bit-issues). Then the new process calls `exec()`, throws out all this and finally creates a new process with the correct executable. From f9f05a98257dc4d8e42b11e6b4a093393c25b163 Mon Sep 17 00:00:00 2001 From: David Macek Date: Sat, 9 Nov 2019 16:00:17 +0100 Subject: [PATCH 385/591] Fix typo --- ...h-quotation,-Executable-bit-and-file-modes,-core.FileMode.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/File-names,-Branch-names,-Path-quotation,-Executable-bit-and-file-modes,-core.FileMode.md b/File-names,-Branch-names,-Path-quotation,-Executable-bit-and-file-modes,-core.FileMode.md index f4aedb8b593068..bbbcbd71daa69d 100644 --- a/File-names,-Branch-names,-Path-quotation,-Executable-bit-and-file-modes,-core.FileMode.md +++ b/File-names,-Branch-names,-Path-quotation,-Executable-bit-and-file-modes,-core.FileMode.md @@ -26,7 +26,7 @@ Users may need to directly manipulate the mode bits where necessary - the [stack # core.FileMode -The core.FileMode configuration records, for the locally cloned repository, the local file system semantics (i.e. is it case sensitive / case preserving or not). DO NOT change this, unless it is actually set wrong. Git will trust this setting and miss-setting it may cause unexpected effects and damage - Don't do it, the internet, as ever, is probably wrong. +The core.FileMode configuration records, for the locally cloned repository, the local file system semantics (i.e. is it case sensitive / case preserving or not). DO NOT change this, unless it is actually set wrong. Git will trust this setting and mis-setting it may cause unexpected effects and damage - Don't do it, the internet, as ever, is probably wrong. From https://git-scm.com/docs/git-config#git-config-corefileMode > Tells Git if the executable bit of files in the working tree is to be honored. From b222d3c8e2b07b50bcb15f2f54af1d2ccfb1279d Mon Sep 17 00:00:00 2001 From: David Macek Date: Sat, 9 Nov 2019 16:01:25 +0100 Subject: [PATCH 386/591] Fix capitalization --- FAQ.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/FAQ.md b/FAQ.md index f6f525c33ba50f..15c69debb247c2 100644 --- a/FAQ.md +++ b/FAQ.md @@ -68,7 +68,7 @@ These often 'fix' (or attempt fixes) recent issues before a new formal release. *Git for Windows* defaults to using [mintty](https://code.google.com/p/mintty/) terminal. Compared to default Windows console host, it provides normal multi-line cut&paste, working resizing, defaults to unicode font and avoids some bugs in the default console host. However it does not present itself as console to native applications (those *not* built with MSys or Cygwin), so in these applications: - * Non-ascii output may be corrupted due to mismatch in character sets (MSys and Cygwin use utf-8 while Windows will fall back to the legacy dos codepages in this case). + * Non-ASCII output may be corrupted due to mismatch in character sets (MSYS2 and Cygwin use UTF-8 while Windows will fall back to the legacy DOS codepages in this case). * Interactive and full-screen applications won't work at all. There are several methods for working around these problems: From 4a1e09bff3255c8400b190a17b9c21457cd1765d Mon Sep 17 00:00:00 2001 From: David Macek Date: Sun, 10 Nov 2019 11:17:42 +0100 Subject: [PATCH 387/591] Fix idiom --- Building-msys2-runtime.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Building-msys2-runtime.md b/Building-msys2-runtime.md index 72daa3cb072f63..ad03aa0ec3bd9a 100644 --- a/Building-msys2-runtime.md +++ b/Building-msys2-runtime.md @@ -18,7 +18,7 @@ When there are bugs in the msys2-runtime (e.g. problems with the POSIX-to-Windows path mangling), you need to rebuild the `msys-2.0.dll`, possibly frequently. -To rebuild the `msys-2.0.dll` -- assuming that you have built it already as described above -- you first need to start an *MSys* shell by double-clicking the `msys2_shell.cmd` script in your Git SDK's top-level directory. Then call `cd /usr/src/MSYS2-packages/msys2-runtime/src/msys2-runtime/winsup/cygwin`. Now you can modify the source code to your heart's extent. It is actually a local clone of https://github.com/git-for-windows/msys2-runtime; you probably want to add your own fork as a remote. +To rebuild the `msys-2.0.dll` -- assuming that you have built it already as described above -- you first need to start an *MSys* shell by double-clicking the `msys2_shell.cmd` script in your Git SDK's top-level directory. Then call `cd /usr/src/MSYS2-packages/msys2-runtime/src/msys2-runtime/winsup/cygwin`. Now you can modify the source code to your heart's content. It is actually a local clone of https://github.com/git-for-windows/msys2-runtime; you probably want to add your own fork as a remote. To actually build the `msys-2.0.dll`, switch to `src/build--pc-msys/-pc-msys/winsup/cygwin` and type `make`. This will generate an `msys0.dll` file in that directory. This is the new `msys-2.0.dll`, but you cannot simply copy it into `/usr/bin/` because it is in use by the current `mintty` as well as by the current Bash. To update, you need to close all programs using the msys2-runtime (including all of the terminal windows), then copy the `msys0.dll` file, replacing the existing `/usr/bin/msys-2.0.dll`, either using Explorer, `cmd.exe` or a separate Git SDK (for example, when debugging the 64-bit msys2-runtime, a 32-bit Git SDK comes in real handy). You will **want** to make a backup copy of the old `msys-2.0.dll`... From e86130b66e87f19fbf07d99f6e71d3a1a77b1e78 Mon Sep 17 00:00:00 2001 From: lxy <391861737@qq.com> Date: Mon, 11 Nov 2019 11:11:56 +0800 Subject: [PATCH 388/591] Updated Install or update inside MSYS2, Cygwin or Git for windows itself (markdown) --- ...-or-update-inside-MSYS2,-Cygwin-or-Git-for-windows-itself.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Install-or-update-inside-MSYS2,-Cygwin-or-Git-for-windows-itself.md b/Install-or-update-inside-MSYS2,-Cygwin-or-Git-for-windows-itself.md index 820e1e955b7651..c9d10d608e5592 100644 --- a/Install-or-update-inside-MSYS2,-Cygwin-or-Git-for-windows-itself.md +++ b/Install-or-update-inside-MSYS2,-Cygwin-or-Git-for-windows-itself.md @@ -4,7 +4,7 @@ Instead of configuring and installing `Git-for-windows` using `Pacman`, this gui ## How to -With the script `getgit` introduced by [git-for-windows/build-extra#261](https://github.com/git-for-windows/build-extra/pull/261), you can download and run the script or just run `curl https://raw.githubusercontent.com/git-for-windows/build-extra/gitupdate/git-extra/getgit | bash`. +With the script `getgit` introduced by [git-for-windows/build-extra#261](https://github.com/git-for-windows/build-extra/pull/261), you can download and run the script or just run `curl https://raw.githubusercontent.com/git-for-windows/build-extra/master/git-extra/getgit | bash`. The script would gather information about the current system ( *Msys / Cygwin* ), bitness, version of an already existed git-for-windows, version of the latest released git-for-windows... and then forge a proper download URL targeting a proper version of the `PortableGit` installer. With all the information prepared, the script would download the installer and unpack it to `/tmp`. After that, all the necessary files will be copied to a proper place inside the ( *Msys's / Cygwin's* ) file system without touching any existing **non-git-for-windows-exclusive** files. From 9ee359abb12c87e0f6d9964ab214d1cf778d74f2 Mon Sep 17 00:00:00 2001 From: David Macek Date: Mon, 11 Nov 2019 21:27:13 +0100 Subject: [PATCH 389/591] Use proper names, especially "Git for Windows" --- ...e-inside-MSYS2,-Cygwin-or-Git-for-windows-itself.md | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/Install-or-update-inside-MSYS2,-Cygwin-or-Git-for-windows-itself.md b/Install-or-update-inside-MSYS2,-Cygwin-or-Git-for-windows-itself.md index c9d10d608e5592..5e0df05173bb01 100644 --- a/Install-or-update-inside-MSYS2,-Cygwin-or-Git-for-windows-itself.md +++ b/Install-or-update-inside-MSYS2,-Cygwin-or-Git-for-windows-itself.md @@ -1,16 +1,16 @@ ## It's different from [Install inside MSYS2 proper](https://github.com/git-for-windows/git/wiki/Install-inside-MSYS2-proper) -Instead of configuring and installing `Git-for-windows` using `Pacman`, this guide introduces another approach to properly install or update `git-for-windows` inside `MSYS2`, `Cygwin` or even `Git-for-windows` itself. The only thing you need is a `bash` interpreter on windows and a `curl`. +Instead of configuring and installing Git for Windows using `pacman`, this guide introduces another approach to properly install or update Git for Windows inside MSYS2, Cygwin or even Git for Windows itself. The only thing you need is a `bash` interpreter on Windows and a `curl`. ## How to With the script `getgit` introduced by [git-for-windows/build-extra#261](https://github.com/git-for-windows/build-extra/pull/261), you can download and run the script or just run `curl https://raw.githubusercontent.com/git-for-windows/build-extra/master/git-extra/getgit | bash`. -The script would gather information about the current system ( *Msys / Cygwin* ), bitness, version of an already existed git-for-windows, version of the latest released git-for-windows... and then forge a proper download URL targeting a proper version of the `PortableGit` installer. +The script would gather information about the current system ( *Msys / Cygwin* ), bitness, version of an already existed Git for Windows, version of the latest released Git for Windows... and then forge a proper download URL targeting a proper version of the `PortableGit` installer. With all the information prepared, the script would download the installer and unpack it to `/tmp`. After that, all the necessary files will be copied to a proper place inside the ( *Msys's / Cygwin's* ) file system without touching any existing **non-git-for-windows-exclusive** files. -Additionally, the `getgit` script will produce two scripts `ctxmenu.bat` and `rm-ctxmenu.bat` which could add and remove `Git GUI Here` and `Git Bash Here` context menu items. But note that, these two context menu items although seem alike with the ones of `Git-for-windows`, they are actually **different**! They just provided similar outcomes and functionality yet still not the same things. +Additionally, the `getgit` script will produce two scripts `ctxmenu.bat` and `rm-ctxmenu.bat` which could add and remove `Git GUI Here` and `Git Bash Here` context menu items. But note that, these two context menu items although seem alike with the ones of Git for Windows, they are actually **different**! They just provided similar outcomes and functionality yet still not the same things. ## Known issue -* On Cygwin, the final `Git Bash Here` won't have a nice prompt that has the current branch of a git repo folder shown. To fix this, you need to remove the `PS1=...` line in the `/etc/bash.bashrc`. -* If some `Permission denied` errors raised, please run your `bash` as Administrator to make sure this script runs with write privilege granted. And if something similar happens against `ctxmenu.bat` script or `rm-ctxmenu.bat`, run it as **Administrator** as well. +* On Cygwin, the final `Git Bash Here` won't have a nice prompt that has the current branch of a git repo folder shown. To fix this, you need to remove the `PS1=...` line in `/etc/bash.bashrc`. +* If some `Permission denied` errors raised, please run your `bash` as Administrator to make sure this script runs with write privilege granted. And if something similar happens against `ctxmenu.bat` script or `rm-ctxmenu.bat`, run it as Administrator as well. From bc85d2d24789cbf4e1e99639d0bd3ad65e10ec77 Mon Sep 17 00:00:00 2001 From: David Macek Date: Mon, 11 Nov 2019 21:28:58 +0100 Subject: [PATCH 390/591] Fix formatting --- Issue-reporting-guidelines.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Issue-reporting-guidelines.md b/Issue-reporting-guidelines.md index c44e9204942fa3..c9114763529b84 100644 --- a/Issue-reporting-guidelines.md +++ b/Issue-reporting-guidelines.md @@ -1,5 +1,5 @@ * Search the existing [open](https://github.com/git-for-windows/git/issues?q=is%3Aopen) and [closed](https://github.com/git-for-windows/git/issues?q=is%3Aclosed) issues. Maybe the bug was already reported? -* Include the output of git --version and the Windows version. In case the issue might depend on the server include its git version and Windows version also. Of course, if you use a 32-bit Windows or 32-bit Git on a 64-bit Windows, you really want to mention that, too. +* Include the output of `git --version` and the Windows version. In case the issue might depend on the server include its git version and Windows version also. Of course, if you use a 32-bit Windows or 32-bit Git on a 64-bit Windows, you really want to mention that, too. * Mention what options you chose when installing Git for Windows, what console window you use (if any), anything that will make it easier to understand what exactly you tried. * If your setup is different from "normal" setups in any way, it is a good idea to put specifics about that into your bug report, too. * Describe your issue properly. If you spend 30 seconds throwing out a sloppy report, do expect that others will spend exactly the same amount on trying to resolve it. In contrast, if you write a complete and pleasantly informative bug report, you will almost certainly be rewarded by excellent help with your problem. From 0bd3d104c95d2f74a918f342cca40fc7a8b6565d Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Fri, 29 Nov 2019 19:43:47 +0100 Subject: [PATCH 391/591] Rename a document so that it can be checked out on Windows Colons are not allowed in Windows filenames... Signed-off-by: Johannes Schindelin --- 0.-Index.md | 2 +- The-difference-between-MINGW-and-MSYS2.md | 4 ++-- .../exec()-semantics.md | 0 3 files changed, 3 insertions(+), 3 deletions(-) rename fork(),-exec(),-CreateProcess():-Windows-vs-Linux.md => Windows-vs-Linux-fork()/exec()-semantics.md (100%) diff --git a/0.-Index.md b/0.-Index.md index 3077da140eddfa..a648b2cd37e4db 100644 --- a/0.-Index.md +++ b/0.-Index.md @@ -13,7 +13,7 @@ This is for the poor souls in corporate IE environments who can't expand the pag * [Diagnosing performance issues](https://github.com/git-for-windows/git/wiki/Diagnosing-performance-issues) * [FAQ](https://github.com/git-for-windows/git/wiki/FAQ) * [File names, Branch names, Path quotation, Executable bit and file modes, core.FileMode](https://github.com/git-for-windows/git/wiki/File-names,-Branch-names,-Path-quotation,-Executable-bit-and-file-modes,-core.FileMode) -* [fork(), exec(), CreateProcess(): Windows vs Linux](https://github.com/git-for-windows/git/wiki/fork(),-exec(),-CreateProcess():-Windows-vs-Linux) +* [fork(), exec(), CreateProcess(): Windows vs Linux](https://github.com/git-for-windows/git/wiki/Windows-vs-Linux-fork()/exec()-semantics) * [Git cannot create a file or directory with a long path](https://github.com/git-for-windows/git/wiki/Git-cannot-create-a-file-or-directory-with-a-long-path) * [Good commits](https://github.com/git-for-windows/git/wiki/Good-commits) * [How to participate](https://github.com/git-for-windows/git/wiki/How-to-participate) diff --git a/The-difference-between-MINGW-and-MSYS2.md b/The-difference-between-MINGW-and-MSYS2.md index 3806a20a1e4c9c..a2366d9e83776e 100644 --- a/The-difference-between-MINGW-and-MSYS2.md +++ b/The-difference-between-MINGW-and-MSYS2.md @@ -36,7 +36,7 @@ Now, to understand the packages' names better, we need to understand how MSYS2 p MSYS2's runtime is `\usr\bin\msys-2.0.dll`. It is an implicit dependency of all MSYS2 executables (most of which live in \usr\bin). This runtime provides emulation for all POSIX functionality enjoyed e.g. by Linux software. This means that it is *a lot* easier to port Linux projects to MSYS2 than it is to straight Windows. So when porting Bash or OpenSSH, it is much, much easier to port them to an MSYS2 package. So why don't we just make all packages MSYS2 ones? The POSIX emulation is *slow*. Like, really, really noticeably slow. -So it is much preferred to port Linux software to pure Win32 calls, without going the POSIX emulation route. Of course, this is a ton more work *per project*. That is the reason why this is not done for all packages. You may want to read [this article](https://github.com/git-for-windows/git/wiki/fork(),-exec(),-CreateProcess():-Windows-vs-Linux) for getting an acquaintance of just a part of underlying problems. +So it is much preferred to port Linux software to pure Win32 calls, without going the POSIX emulation route. Of course, this is a ton more work *per project*. That is the reason why this is not done for all packages. You may want to read [this article](https://github.com/git-for-windows/git/wiki/Windows-vs-Linux-fork()/exec()-semantics) for getting an acquaintance of just a part of underlying problems. Normally, we use Visual C++ compiler on Windows. When building Windows software using GCC, it is necessary to have all the support headers and libraries. They are not provided by Microsoft, but by a separate project called MINGW ("Minimal GNU on Windows"). MSYS2 uses these MINGW libraries (and MINGW GCC compiler) to build pure Win32 packages, and those are called MINGW packages. @@ -58,4 +58,4 @@ To allow for side-by-side installation, the 32-bit MINGW files are installed int Therefore, it lives in `\mingw64\bin\git.exe` (or in `\mingw32\bin\git.exe`), and is bundled in the `mingw-w64-x86_64-git` (or `mingw-w64-i686-git`) package. (That's not the complete truth for documentation and testing packages, but let's concentrate on the main story.) -Pacman (package manager used by MSYS2) has this feature where it regularly adds its own modifications on top of the original source of packages. In Git's case, it adds e.g. the git-wrapper in its various forms, and more. The git-wrapper is pretty specific to the official Git for Windows that is based on MSYS2, though (while we have a task to support both MSys and MSYS2 packages). So it cannot live in git-for-windows/git. It lives in MINGW-packages, in the subdirectory specific to the mingw-w64-git package. \ No newline at end of file +Pacman (package manager used by MSYS2) has this feature where it regularly adds its own modifications on top of the original source of packages. In Git's case, it adds e.g. the git-wrapper in its various forms, and more. The git-wrapper is pretty specific to the official Git for Windows that is based on MSYS2, though (while we have a task to support both MSys and MSYS2 packages). So it cannot live in git-for-windows/git. It lives in MINGW-packages, in the subdirectory specific to the mingw-w64-git package. diff --git a/fork(),-exec(),-CreateProcess():-Windows-vs-Linux.md b/Windows-vs-Linux-fork()/exec()-semantics.md similarity index 100% rename from fork(),-exec(),-CreateProcess():-Windows-vs-Linux.md rename to Windows-vs-Linux-fork()/exec()-semantics.md From 3b9d0ac5995771337523fba0ce8e9ecbfd4fdd97 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Tue, 3 Dec 2019 16:41:19 +0100 Subject: [PATCH 392/591] As pointed out by @Osse, this use case is not supported by Git for Windows --- Install-inside-MSYS2-proper.md | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index 476cd5c34125d0..f329e5965102e1 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -1,3 +1,7 @@ +# **Please note that this scenario is not officially supported by Git for Windows** + +(The reason this is unsupported is that there are no volunteers to support that scenario.) + **This guide assumes that you want the 64-bit version of Git for Windows.** Git for Windows being based on MSYS2, it's possible to install the `git` package into an existing MSYS2 installation. That means that if you are already using MSYS2 on your computer, you can use Git for Windows without running the full installer or using the portable version. From 4de69589e23c173412d9f8d4189b92b3a33a20ec Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Tue, 3 Dec 2019 17:03:51 +0000 Subject: [PATCH 393/591] Initial draft for testing --- ...r-and-linkage-to-Visual-Studio,-for-Git.md | 32 +++++++++++++++++++ 1 file changed, 32 insertions(+) create mode 100644 Sourcetrail-code-viewer-and-linkage-to-Visual-Studio,-for-Git.md diff --git a/Sourcetrail-code-viewer-and-linkage-to-Visual-Studio,-for-Git.md b/Sourcetrail-code-viewer-and-linkage-to-Visual-Studio,-for-Git.md new file mode 100644 index 00000000000000..504b5ac0fe312c --- /dev/null +++ b/Sourcetrail-code-viewer-and-linkage-to-Visual-Studio,-for-Git.md @@ -0,0 +1,32 @@ +[Sourcetrail](https://www.sourcetrail.com) is an interactive source explorer that simplifies navigation in existing source code. It is [now open source](https://www.sourcetrail.com/blog/open_source/). + +This note is a quick start to setting up a Sourcetrail project for exploring the Git source code in conjunction with Visual Studio. Source trail is configurable and some parameter need to be set on initial project setup. + +1. Git-for-Windows is available as a Visual Studio .sln in the `vs/master` [branch](https://github.com/git-for-windows/git/tree/vs/master) . It comprise ~19 sub-projects including `git` and `libgit`. +2. This was tested with the free VS2017 community edition. +3. Build the solution(.sln) in Visual Studio so that it's `vcpkg` dependencies are downloaded and compiled (may take some time). +4. Download and install the Sourcetrail software. Check the [documentation](https://www.sourcetrail.com/documentation/), especially the [intro video](https://youtu.be/7fguPwKR_7Y). +5. Download and install the [VS Sourcetrail Extension](https://marketplace.visualstudio.com/items?itemName=vs-publisher-1208751.SourcetrailExtension). + +For Git, Sourcetrail will need it's pre-processor dependencies which are numerous, so let's extract them from Visual Studio. We need to collect the main preprocessor directives from `libgit` (which everything depends on) and `git`. + +1. Browse the VS project properties. Find the C/C++ tab list, open find 'Preprocessor', then (see top of list) "Preprocessor Definitions" with a long list of ";" separated values. Copy them for both `git` and `libgit`. +2. Change ";" to "\n-D " (i.e. newline then -D ), with a `-D ` for the first value as well, etc. +3. Add `-std=C99` and `-nologo` options to the option list, which now should be one per line. +4. don't worry about duplicates. Internally Sourcetrail uses a Clang compiler with a 'last one wins' where required. + +Now let's create the Sourcetrail project +1. Open Sourcetrail. Leave at the initial prompt. +2. In VS, from the Sourcetrail menu, export the compile database, selecting C99 standard. +3. Switch back to Sourcetrail "New Source Group" window. + +Headers & directories to index: click 'select from Compilation database', then tick './' only (leave all the 'Windows Kits' unchecked). scroll down, "exluded's" left blank; +"additional compile flags" selecting the scribble pen icon, paste in the "Preprocessor Definitions" (one per line) prepared above. +Next + +(flicks back to the New Project dialog, but as it is still selecting the source groups (C/C++ from Comp Db) its looks unchanged), select "General" in top left side, and update the project name to (e.g.) "Git_sourcetrail". location is "ok C:/git-sdk-64/usr/src/git". +"Create" ! +switch back to the other Sourcetrail window (now active, with a fresh blue 'start Indexing' dialog). "All files" (dot in circle) should already be selected. +Click 'Start', wait ~one minute (00:01:38). + +Should work. \ No newline at end of file From d816d5f8040ea7db4d976a83ce1cec75d4458dd2 Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Tue, 3 Dec 2019 17:10:58 +0000 Subject: [PATCH 394/591] tweaks --- ...-viewer-and-linkage-to-Visual-Studio,-for-Git.md | 13 +++++++------ 1 file changed, 7 insertions(+), 6 deletions(-) diff --git a/Sourcetrail-code-viewer-and-linkage-to-Visual-Studio,-for-Git.md b/Sourcetrail-code-viewer-and-linkage-to-Visual-Studio,-for-Git.md index 504b5ac0fe312c..233a4dc41364e3 100644 --- a/Sourcetrail-code-viewer-and-linkage-to-Visual-Studio,-for-Git.md +++ b/Sourcetrail-code-viewer-and-linkage-to-Visual-Studio,-for-Git.md @@ -1,4 +1,4 @@ -[Sourcetrail](https://www.sourcetrail.com) is an interactive source explorer that simplifies navigation in existing source code. It is [now open source](https://www.sourcetrail.com/blog/open_source/). +[Sourcetrail](https://www.sourcetrail.com) is an interactive source explorer that simplifies navigation in existing source code. It is [now open source](https://www.sourcetrail.com/blog/open_source/). You can support them on Patreon. This note is a quick start to setting up a Sourcetrail project for exploring the Git source code in conjunction with Visual Studio. Source trail is configurable and some parameter need to be set on initial project setup. @@ -21,12 +21,13 @@ Now let's create the Sourcetrail project 3. Switch back to Sourcetrail "New Source Group" window. Headers & directories to index: click 'select from Compilation database', then tick './' only (leave all the 'Windows Kits' unchecked). scroll down, "exluded's" left blank; -"additional compile flags" selecting the scribble pen icon, paste in the "Preprocessor Definitions" (one per line) prepared above. +"Additional Compile Flags" selecting the scribble pen icon, paste in the "Preprocessor Definitions" (one per line) prepared above. Next -(flicks back to the New Project dialog, but as it is still selecting the source groups (C/C++ from Comp Db) its looks unchanged), select "General" in top left side, and update the project name to (e.g.) "Git_sourcetrail". location is "ok C:/git-sdk-64/usr/src/git". -"Create" ! -switch back to the other Sourcetrail window (now active, with a fresh blue 'start Indexing' dialog). "All files" (dot in circle) should already be selected. -Click 'Start', wait ~one minute (00:01:38). +(flicks back to the New Project dialog, but as it is still selecting the source groups (C/C++ from Compilation Database) its looks unchanged), +select "General" in top left side, and update the project name to (e.g.) "Git_sourcetrail". Location is usually ok e.g."C:/git-sdk-64/usr/src/git". +"Create" ! +switch back to the other Sourcetrail window (now active, with a fresh blue 'start Indexing' dialog). "All files" (dot in circle) should already be selected. +Click 'Start', wait ~one minute (00:01:38). Should work. \ No newline at end of file From 6735973f0cef2369d66f2b4afcdb5809598a7e1d Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Tue, 3 Dec 2019 17:14:36 +0000 Subject: [PATCH 395/591] added extra page --- 0.-Index.md | 1 + 1 file changed, 1 insertion(+) diff --git a/0.-Index.md b/0.-Index.md index a648b2cd37e4db..2a82202aabf271 100644 --- a/0.-Index.md +++ b/0.-Index.md @@ -33,6 +33,7 @@ This is for the poor souls in corporate IE environments who can't expand the pag * [Running Git's regression tests](https://github.com/git-for-windows/git/wiki/Running-Git's-regression-tests) * [Setting your Core.Editor ( e.g. Notepad )](https://github.com/git-for-windows/git/wiki/Setting-your-Core.Editor-(-e.g.-Notepad-)) * [Silent or Unattended Installation](https://github.com/git-for-windows/git/wiki/Silent-or-Unattended-Installation) +* [Sourcetrail code viewer and linkage to Visual Studio, for Git](https://github.com/git-for-windows/git/wiki/Sourcetrail-code-viewer-and-linkage-to-Visual-Studio,-for-Git) * [Symbolic Links](https://github.com/git-for-windows/git/wiki/Symbolic-Links) * [The difference between MINGW and MSYS2](https://github.com/git-for-windows/git/wiki/The-difference-between-MINGW-and-MSYS2) * [Updating your SDK](https://github.com/git-for-windows/git/wiki/Updating-your-SDK) From c124a2c06af607fe2397c21784c651e6e3e2efe3 Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Tue, 3 Dec 2019 17:18:30 +0000 Subject: [PATCH 396/591] added Sourcetrail link --- Compiling-Git-with-Visual-Studio.md | 7 ++++++- 1 file changed, 6 insertions(+), 1 deletion(-) diff --git a/Compiling-Git-with-Visual-Studio.md b/Compiling-Git-with-Visual-Studio.md index 67d8890f5f9ef1..94474aaa2e8c85 100644 --- a/Compiling-Git-with-Visual-Studio.md +++ b/Compiling-Git-with-Visual-Studio.md @@ -32,4 +32,9 @@ You can use the `prove` tool (which *mostly* works reliably, sometimes you will ```sh prove --timer --jobs 15 ./t[0-9]*.sh -``` \ No newline at end of file +``` + + +# Browsing the code + +You can also use the Sourcetrail code browser (now open source) in conjunction with Visual Studio, see [Sourcetrail code viewer](https://github.com/git-for-windows/git/wiki/Sourcetrail-code-viewer-and-linkage-to-Visual-Studio,-for-Git) page. \ No newline at end of file From 83c2b5fbc55bcbe574bff50eea80d8c02c98bfe0 Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Tue, 3 Dec 2019 18:24:31 +0000 Subject: [PATCH 397/591] corrected c99 and corrected some of sequence --- ...r-and-linkage-to-Visual-Studio,-for-Git.md | 26 ++++++++++--------- 1 file changed, 14 insertions(+), 12 deletions(-) diff --git a/Sourcetrail-code-viewer-and-linkage-to-Visual-Studio,-for-Git.md b/Sourcetrail-code-viewer-and-linkage-to-Visual-Studio,-for-Git.md index 233a4dc41364e3..780b91fcebe41a 100644 --- a/Sourcetrail-code-viewer-and-linkage-to-Visual-Studio,-for-Git.md +++ b/Sourcetrail-code-viewer-and-linkage-to-Visual-Studio,-for-Git.md @@ -10,24 +10,26 @@ This note is a quick start to setting up a Sourcetrail project for exploring the For Git, Sourcetrail will need it's pre-processor dependencies which are numerous, so let's extract them from Visual Studio. We need to collect the main preprocessor directives from `libgit` (which everything depends on) and `git`. -1. Browse the VS project properties. Find the C/C++ tab list, open find 'Preprocessor', then (see top of list) "Preprocessor Definitions" with a long list of ";" separated values. Copy them for both `git` and `libgit`. -2. Change ";" to "\n-D " (i.e. newline then -D ), with a `-D ` for the first value as well, etc. -3. Add `-std=C99` and `-nologo` options to the option list, which now should be one per line. -4. don't worry about duplicates. Internally Sourcetrail uses a Clang compiler with a 'last one wins' where required. +1. Browse the VS project properties. Find the `C/C++` tab list, open, find 'Preprocessor', then (see top of list) "Preprocessor Definitions" with a long list of ";" separated values. Copy them for both `git` and `libgit` into your favourite editor. +2. Change ";" to "\n-D " (i.e. newline then -D ), with a `-D ` for the first value from each original line as well, etc. +3. Remove the "-D %(additional..)" lines. +4. Add `-std=c99` and `-nologo` options to the end of the option list, which now should be one per line. +5. Don't worry about duplicates. Internally Sourcetrail uses a Clang compiler with a 'last one wins' where required. Now let's create the Sourcetrail project 1. Open Sourcetrail. Leave at the initial prompt. 2. In VS, from the Sourcetrail menu, export the compile database, selecting C99 standard. 3. Switch back to Sourcetrail "New Source Group" window. -Headers & directories to index: click 'select from Compilation database', then tick './' only (leave all the 'Windows Kits' unchecked). scroll down, "exluded's" left blank; -"Additional Compile Flags" selecting the scribble pen icon, paste in the "Preprocessor Definitions" (one per line) prepared above. -Next +4. "Headers & directories to index": click 'select from Compilation database', then tick './' only (leave all the 'Windows Kits' unchecked). scroll down, "exluded's" left blank; Next. -(flicks back to the New Project dialog, but as it is still selecting the source groups (C/C++ from Compilation Database) its looks unchanged), -select "General" in top left side, and update the project name to (e.g.) "Git_sourcetrail". Location is usually ok e.g."C:/git-sdk-64/usr/src/git". -"Create" ! -switch back to the other Sourcetrail window (now active, with a fresh blue 'start Indexing' dialog). "All files" (dot in circle) should already be selected. -Click 'Start', wait ~one minute (00:01:38). +(flicks back to the New Project dialog, but as it is still selecting the source groups (C/C++ from Compilation Database) its looks unchanged), + +5. scroll down, "Additional Compile Flags" selecting the scribble pen icon, paste in the "Preprocessor Definitions" (one per line) prepared above. +6. select "General" in top left side, and update the project name to (e.g.) "Git_sourcetrail". Location is usually ok e.g."C:/git-sdk-64/usr/src/git". +"Create" ! (or maybe Next) + +* switch back to the other Sourcetrail window (now active, with a fresh blue 'start Indexing' dialog). "All files" (dot in circle) should already be selected. +* Click 'Start', wait ~one minute (00:01:38). Should work. \ No newline at end of file From b79c426ebdd5ff0281fa775e3fff83faaf6cb4d9 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Tue, 10 Dec 2019 21:30:40 +0100 Subject: [PATCH 398/591] Recommend updating to v2.24.1(2) --- FAQ.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/FAQ.md b/FAQ.md index 15c69debb247c2..171e561f368b5d 100644 --- a/FAQ.md +++ b/FAQ.md @@ -27,7 +27,7 @@ In the meantime you could try: In general, yes: it is a good idea to stay up-to-date. -If you have a version older than 2.17.1(2), it is *highly* advisable to upgrade. A couple of Git versions came with important fixes to security-relevant vulnerabilities: 2.17.1(2), 2.14.1, 2.7.4, 2.7.0, 2.6.1, 2.5.2, 1.9.5-preview20150319, and 1.9.5-preview20141217. +If you have a version older than 2.24.1(2), it is *highly* advisable to upgrade. A couple of Git versions came with important fixes to security-relevant vulnerabilities: 2.24.1(2), 2.17.1(2), 2.14.1, 2.7.4, 2.7.0, 2.6.1, 2.5.2, 1.9.5-preview20150319, and 1.9.5-preview20141217. ## What is the release cadence of Git for Windows? From 2edf0bd4b43a65b1db79898b7e5bc175d5e3088e Mon Sep 17 00:00:00 2001 From: "Nicholas Prado (beyondRelations)" <46462286+BR-Nicholas-Prado@users.noreply.github.com> Date: Mon, 13 Jan 2020 14:06:55 -0600 Subject: [PATCH 399/591] FIX: Substitutes an idiomatic positive emphasis, rather than a contradicting emphasis. This better communicates that the surrounding sentence emphasizes the preceeding, rather than mollifying it --- Home.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Home.md b/Home.md index 10fff6fa423e5e..cb7c142b2716cf 100644 --- a/Home.md +++ b/Home.md @@ -20,7 +20,7 @@ And yes, the idea is still the same as the original one: Update the _MSYS2_ setu Now, keep in mind that _MSYS2_ and Linux (The original target for _Git_'s distribution) are very different beasts. Their distributions might include packages that are built from the same source code (i.e. the `binutils`, `gcc` or `bash` package), but the runtime is very, very different: _MSYS2_'s runtime is a stripped-down, slightly modified _Cygwin_ runtime running on top of the Windows kernel, while Linux' runtime is the Linux kernel, running as a separate OS altogether. -So if you are missing some packages - feel free to start making one. This is Open Source, however, so everybody interested and capable enough can contribute whatever they need to address their needs. And that includes you: you could imitate e.g. [a simple `PKGBUILD` file](https://github.com/Alexpux/MINGW-packages/blob/master/mingw-w64-assimp-git/PKGBUILD) to build a new package e.g. `msmtp`, the component that _Git for Windows_ 1.x uses to support `sendemail`. Then open a Pull Request so that _Git for Windows_ can ship it. Our documentation will be helpful in that endeavor: [package-management](https://github.com/git-for-windows/git/wiki/Package-management), in particular [package-management#rebuild-packages](https://github.com/git-for-windows/git/wiki/Package-management#rebuild-packages). +So if you are missing some packages - feel free to start making one. This is Open Source, after all, so everybody interested and capable enough can contribute whatever they need to address their needs. And that includes you: you could imitate e.g. [a simple `PKGBUILD` file](https://github.com/Alexpux/MINGW-packages/blob/master/mingw-w64-assimp-git/PKGBUILD) to build a new package e.g. `msmtp`, the component that _Git for Windows_ 1.x uses to support `sendemail`. Then open a Pull Request so that _Git for Windows_ can ship it. Our documentation will be helpful in that endeavor: [package-management](https://github.com/git-for-windows/git/wiki/Package-management), in particular [package-management#rebuild-packages](https://github.com/git-for-windows/git/wiki/Package-management#rebuild-packages). # Start documenting If you need inspiration what you could write about: document your common work flows. Write a tutorial how to start coding _Git for Windows_, how to run the test suite. Write a tutorial how to debug a failing test. Write about something you would have wished you had known about Git for Windows a long time ago. From 6f8b4532941d064a57fda94019658c600aff1be1 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Wed, 29 Jan 2020 11:07:11 +0100 Subject: [PATCH 400/591] Clarify first paragraph (pointed out by @elieux) --- Home.md | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/Home.md b/Home.md index cb7c142b2716cf..9c9fc18251a29f 100644 --- a/Home.md +++ b/Home.md @@ -2,9 +2,7 @@ The _Git for Windows_ wiki. It looks more technical than [our home page](https://gitforwindows.org/) because it is the place where *you* [can contribute](https://github.com/git-for-windows/git/wiki/How-to-participate) to the documentation about _Git for Windows_. ## About -_Git for Windows_ is very different from _Git_ for almost everything else in one important respect: Windows does not provide the *POSIX* infrastructure Git expects. - -Therefore, it always had to ship with much more than any other Git distribution: provide a `bash`, a `perl`, many *POSIX* tools such as `sed`, `awk`, `tr`, etc. +_Git for Windows_ is very different from _Git_ in one very important respect: As Windows does not provide the *POSIX* infrastructure Git expects, Git for Windows always had to ship with much more than any other Git distribution: provide a `bash`, a `perl`, many *POSIX* tools such as `sed`, `awk`, `tr`, etc. Git for Windows 1.x did that by starting off from an [MSys](http://www.mingw.org/wiki/msys) installation and just packaging all the required files as-are. _MSys_ did not sport any package manager at the time, so all of the updates were quite manual, and some of the components we shipped were not even part of _MSys_ -- such as `msmtp` or `WhoUses` -- so we had to compile them from scratch, and maintain those components ourselves. From 1643bd590d4c43b6aaf7ed8546b7b6a41398b06c Mon Sep 17 00:00:00 2001 From: David Macek Date: Wed, 29 Jan 2020 11:49:30 +0100 Subject: [PATCH 401/591] Package management: Correct names --- Package-management.md | 13 ++++++------- 1 file changed, 6 insertions(+), 7 deletions(-) diff --git a/Package-management.md b/Package-management.md index fe4714247b0bab..4b56fd929685aa 100644 --- a/Package-management.md +++ b/Package-management.md @@ -1,6 +1,6 @@ -Modern software development relies heavily on a way to manage dependencies, i.e. to keep track of required software libraries and their versions. Examples are `apt-get` for Linux, `homebrew` for MacOSX, `Maven` for Java and `pip` for Python. +Modern software development relies heavily on a way to manage dependencies, i.e. to keep track of required software libraries and their versions. Examples are `apt` for Linux, `homebrew` for macOS, `maven` for Java and `pip` for Python. -Git for Windows is based on [MSYS2](https://msys2.github.io/) which bundles Arch Linux' [Pacman](https://wiki.archlinux.org/index.php/Pacman) tool for dependency management. +Git for Windows is based on [MSYS2](https://msys2.github.io/) which bundles the [Pacman](https://wiki.archlinux.org/index.php/Pacman) tool (known from Arch Linux) for dependency management. # How to use `pacman` @@ -65,10 +65,10 @@ pacman -Qo If you want to rebuild a package, the first order of business is to know which repository has the metadata for the package. Git for Windows has three repositories containing such metadata: - [build-extra](https://github.com/git-for-windows/build-extra) contains the `git-extra` package information, -- [MINGW-packages](https://github.com/git-for-windows/MINGW-packages) contains the information for the MinGW packages, i.e. packages that do not require any POSIX emulation; by convention, their package name have the `mingw-w64-` prefix, and +- [MINGW-packages](https://github.com/git-for-windows/MINGW-packages) contains the information for the MINGW packages, i.e. packages that do not require any POSIX emulation; by convention, their package name have the `mingw-w64-` prefix, and - [MSYS2-packages](https://github.com/git-for-windows/MSYS2-packages) contains the information for all packages that require a POSIX emulation, such as Bash, OpenSSH, etc. The `MSYS2-packages` repository also contains the information of the package *providing* the POSIX emulation: [`msys2-runtime`](https://github.com/git-for-windows/msys2-runtime) (see also [Building msys2-runtime](Building-msys2-runtime)). -To build MinGW packages, you need to start the appropriate `MinGW` shell (32-bit or 64-bit – this sets `MSYSTEM=MINGW32` or `MSYSTEM=MINGW64` respectively), clone the [`MINGW-packages`](https://github.com/git-for-windows/MINGW-packages) repository (recommended location: `/usr/src/MINGW-packages`), `cd` to the appropriate subdirectory and call +To build MINGW packages, you need to start the appropriate *MINGW* shell (32-bit or 64-bit – this sets `MSYSTEM=MINGW32` or `MSYSTEM=MINGW64` respectively), clone the [`MINGW-packages`](https://github.com/git-for-windows/MINGW-packages) repository (recommended location: `/usr/src/MINGW-packages`), `cd` to the appropriate subdirectory and call ```bash makepkg-mingw -s @@ -76,7 +76,7 @@ makepkg-mingw -s (The `-s` flag tells `makepkg` that it should install dependencies automatically as needed) -To build MSys packages, you need to start the `MSys` shell (e.g. `C:\git-sdk-64\msys2_shell.cmd -msys`, which sets `MSYSTEM=MSYS` before running the Bash), clone the [`MSYS2-packages`](https://github.com/git-for-windows/MSYS2-packages) repository (recommended location: `/usr/src/MSYS2-packages`), `cd` to the appropriate subdirectory and call +To build MSYS packages, you need to start the *MSYS* shell (e.g. `C:\git-sdk-64\msys2_shell.cmd -msys`, which sets `MSYSTEM=MSYS` before running the Bash), clone the [`MSYS2-packages`](https://github.com/git-for-windows/MSYS2-packages) repository (recommended location: `/usr/src/MSYS2-packages`), `cd` to the appropriate subdirectory and call ```bash makepkg -s @@ -84,7 +84,7 @@ makepkg -s If you have modified any files (like `PKGBUILD`) you need to update the checksums using the `updpkgsums` command before running `makepkg` or `makepkg-mingw`. -*Note*: Before building the first MSys package, as per [MSYS2's own documentation](http://sourceforge.net/p/msys2/wiki/Contributing%20to%20MSYS2/) you need to install the development packages for development: +*Note*: Before building the first MSYS package, as per [MSYS2's own documentation](http://sourceforge.net/p/msys2/wiki/Contributing%20to%20MSYS2/) you need to install the development packages for development: ```sh pacman -Sy base-devel msys2-devel @@ -100,7 +100,6 @@ makepkg-mingw --noextract --noprepare or - ```bash makepkg --noextract --noprepare ``` From 0a68a03533f6ad9874f33b56899d0e30847caf9f Mon Sep 17 00:00:00 2001 From: David Macek Date: Wed, 29 Jan 2020 11:50:26 +0100 Subject: [PATCH 402/591] Package management: Include bash in MSYS2 core upgrade instructions --- Package-management.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Package-management.md b/Package-management.md index 4b56fd929685aa..9a3b9ee8de55cf 100644 --- a/Package-management.md +++ b/Package-management.md @@ -28,7 +28,7 @@ pacman -Syu ### Updating `msys2-runtime`, `pacman` and `bash` -As `pacman.exe` is itself an MSYS2 executable, it is strongly suggested to update `msys2-runtime` and `pacman` packages individually if they need to be updated, and let `pacman` quit *immediately* afterwards. +As `pacman.exe` is itself an MSYS2 executable, it is strongly suggested to update `msys2-runtime`, `bash` and `pacman` packages separately from other packages if they need to be updated, and let `pacman` quit *immediately* afterwards. Likewise, if you run `pacman` from a `bash` -- an MSYS2 program, too -- you should quit the shell *immediately* (it might show an infinite stream of heap messages instead of quitting, requiring to be force-quit). From fc53b512469083ca7b42a168a090d47639b5a4b3 Mon Sep 17 00:00:00 2001 From: David Macek Date: Wed, 29 Jan 2020 11:52:22 +0100 Subject: [PATCH 403/591] Package management: Fix MSYS2 wiki link --- Package-management.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Package-management.md b/Package-management.md index 9a3b9ee8de55cf..f0a21eba9c4e6e 100644 --- a/Package-management.md +++ b/Package-management.md @@ -84,7 +84,7 @@ makepkg -s If you have modified any files (like `PKGBUILD`) you need to update the checksums using the `updpkgsums` command before running `makepkg` or `makepkg-mingw`. -*Note*: Before building the first MSYS package, as per [MSYS2's own documentation](http://sourceforge.net/p/msys2/wiki/Contributing%20to%20MSYS2/) you need to install the development packages for development: +*Note*: Before building the first MSYS package, as per [MSYS2's own documentation](https://github.com/msys2/msys2/wiki/Creating-Packages) you need to install the development packages for development: ```sh pacman -Sy base-devel msys2-devel From e1ca8c06e16587b3611c5664437a54f6939a4386 Mon Sep 17 00:00:00 2001 From: David Macek Date: Wed, 29 Jan 2020 11:50:48 +0100 Subject: [PATCH 404/591] Package management: Forget BinTray and manual package uploads Signed-off-by: Johannes Schindelin --- Package-management.md | 31 +------------------------------ 1 file changed, 1 insertion(+), 30 deletions(-) diff --git a/Package-management.md b/Package-management.md index f0a21eba9c4e6e..400cdc87c31843 100644 --- a/Package-management.md +++ b/Package-management.md @@ -128,33 +128,4 @@ perl -MCPAN -e shell Pacman repositories are served via HTTP, as static files in a single directory. The most important file in that directory is the *package index*, called `.db.tar.xz` by convention. This package index can be updated via `repo-add ...` (this updated *only* the package index, it does *not* copy the package files into the same directory). Pacman expects to find the package files referenced in the package index in the same directory as the index. -The *Git for Windows*-specific packages are served from Bintray, see [below](#Bintray). -We ship MSYS2 and MinGW packages for two architectures, [`i686`](https://dl.bintray.com/git-for-windows/pacman/i686/) and [`x86_64`](https://dl.bintray.com/git-for-windows/pacman/x86_64/). - -## Bintray - -[Bintray](https://bintray.com) hosts repositories of binary files, much like GitHub hosts repositories of source files. Git for Windows' binary files are [hosted on Bintray](https://bintray.com/git-for-windows/). - -Git for Windows' [most important repository hosted on Bintray](https://bintray.com/git-for-windows/pacman) contains the Pacman repositories [described above](#Repository_structure). The section to add to `pacman.conf` to access this repository is: - -```ini -[git-for-windows] -Server = https://dl.bintray.com/$repo/pacman/$arch -SigLevel = Optional -``` - -## How to upload new versions (*Git for Windows* maintainers only) - -To upload new files, a maintainer needs to have permission to write to the `pacman` repository on Bintray. We have a helpful tool in the [`build-extra`](https://github.com/git-for-windows/build-extra) repository to assist in the process, called `pacman-mirror.sh`. After building a new package version (preferably for 32-bit *and* 64-bit), the tool should be used thusly: - -```bash -/usr/src/build-extra/pacman-mirror.sh fetch -/usr/src/build-extra/pacman-mirror.sh add \ - /path/to/--i686.pkg.tar.xz \ - /path/to/--x86_64.pkg.tar.xz -/usr/src/build-extra/pacman-mirror.sh push -``` - -The `fetch` step will initialize or synchronize the local mirror of the Pacman repository, the `add` step will copy the packages into the appropriate location, and the `push` step will update the package index, and upload the packages that are not yet on Bintray as well as the package index. - -Note: The `pacman-mirror.sh` tool takes no precaution against simultaneous use. You *will* want to coordinate with your fellow maintainers to avoid running it at the same time as somebody else. +The *Git for Windows*-specific packages are served by [Azure Blob Storage](https://azure.microsoft.com/en-us/services/storage/blobs/), see below. We ship MSYS2 and MINGW packages for two architectures, `i686` and `x86_64`. Pacman is configured to use these in `/etc/pacman.conf`. From e24a1f901e0314a66edd559c05947d95accf44ba Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Thu, 30 Jan 2020 14:01:19 +0100 Subject: [PATCH 405/591] Add an introductory summary --- Technical-overview.md | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/Technical-overview.md b/Technical-overview.md index 18f6a4235ddd40..662de031bc5430 100644 --- a/Technical-overview.md +++ b/Technical-overview.md @@ -1,3 +1,5 @@ +Git for Windows is essentially a subset of [MSYS2](https://msys2.github.io/) with a defined set of installed packages of which a subset is included in the installer. + The process to build an instance of the Git for Windows installer is made easier with the `Git for Windows SDK`. Basically, the steps are as follows: 1. Download and install the SDK, which installs the sources for `git`, additional msys and mingw packages, and helpers to build the installer. It also provides the `Git for Windows SDK` MSys shell @@ -57,5 +59,6 @@ The last line of the log shows where the installer packages were created (usuall See also: * [Debugging git](Debugging-Git) with gdb * Running Git's [regression tests](Running-Git's-regression-tests) -* Msys/Mingw [package management](Package-management#technical-details) +* MSYS/MINGW [package management](Package-management#technical-details) * [Updating the SDK](https://github.com/git-for-windows/git/wiki/Updating-your-SDK) +* [MSYS2](https://msys2.github.io/) \ No newline at end of file From 96bb5632a8af4f3325ac97c02b9237469b65ea6d Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Sun, 23 Feb 2020 14:53:57 +0100 Subject: [PATCH 406/591] Add some detail about the built-in commands and their `.exe` files --- Making-an-installer.md | 18 ++++++++++++++++++ 1 file changed, 18 insertions(+) diff --git a/Making-an-installer.md b/Making-an-installer.md index 6e0f20b549ba41..4dc6b439db1ac9 100644 --- a/Making-an-installer.md +++ b/Making-an-installer.md @@ -33,3 +33,21 @@ git pull master ``` where `` is the Git version (please note that the `` cannot contain dots after the numerical version: `2.7.2-hello-world` is okay while `2.7.2.hello.world` is not okay). + +# Why is this installer so much larger than the official installer? + +Short version: you will need to run `make strip` in `/usr/src/git` before `make install`, and you will also need to run to call `pacman -S git-extra` afterwards. + +## Why `make strip`? + +The `make strip` command removes the debug information from the `.exe` files. That is not quite the same as the official release process does: it calls `cv2pdb` which splits out the debug information from the `.exe` files into separate `.pdb` files, but that processing is not defined in `/usr/src/git/Makefile`, but instead in `/usr/src/MINGW-packages/mingw-w64-git/PKGBUILD`. + +## Why `pacman -S git-extra`? + +The `pacman -S git-extra` part is defined elsewhere yet: in `/usr/src/build-extra/please.sh`. Its purpose is to replace many hardlinked copies in `/mingw64/libexec/git-core/git-*.exe` with what Git for Windows calls the "Git wrapper": a small executable that does nothing else but call `git.exe` with the appropriate subcommand name. + +You see, many "built-in" commands are implemented right there in `git.exe`, with no need to actually execute anything else. For example, when you call `git show`, the show part is executed inside `git.exe` itself. + +This is in contrast to, say, `git send-email`, which actually executes `/mingw64/libexec/git-core/git-send-email` (a Perl script). For historical reasons, Git wants to provide also `git-show.exe` in `/mingw64/libexec/git-core/`, even if that is not at all necessary because the show command is a built-in command. Therefore, Git has this quirk where it first looks at the name of the executable via which it was called (e.g. if it was called via `/mingw64/libexec/git-core/git-show.exe`, it extracts the show part and knows that it should internally execute `git show` instead. And then, Git simply installs hardlinked copies of `git.exe` in `/mingw64/libexec/git-core/` for all built-in commands. + +Since they are hard-links, they only use a minuscule amount of disk space. However, too many Git for Windows users looked at the disk usage of those hard-linked copies using the Windows Explorer, which historically completely ignored the fact that hard-linked copies did not use additional disk space (apart from the directory entry). As a consequence, we had many reports that Git for Windows occupied way too much space. That was not true, of course, but those reports took so much time to address that it was easier to install the Git wrapper (which is copied, but it is tiny compared to git.exe). \ No newline at end of file From c5b343a520b5f636d9e323e2959af4131941218c Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Sun, 8 Mar 2020 13:46:16 +0000 Subject: [PATCH 407/591] Updated Updating your SDK (markdown) --- Updating-your-SDK.md | 3 +++ 1 file changed, 3 insertions(+) diff --git a/Updating-your-SDK.md b/Updating-your-SDK.md index d8073488f5d9e2..d544b99fb3d834 100644 --- a/Updating-your-SDK.md +++ b/Updating-your-SDK.md @@ -14,6 +14,9 @@ plus Git for Windows' packages. # Updating the installed SDK +The SDK ships with the script `update-via-pacman.bat` that you can run (but you need to make sure that all Git SDK Bash windows are closed first, i.e. that no processes are running that might lock files that want to be updated) + +Alternatively: To keep the SDK up-to-date, periodically run pacman -Syu From ffe90e676c758ce80e72b10ae184c3dd30089b98 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Thu, 26 Mar 2020 20:55:04 +0100 Subject: [PATCH 408/591] Describe the `Cwd.dll` problem and workaround --- 32-bit-issues.md | 18 +++++++++++++++++- 1 file changed, 17 insertions(+), 1 deletion(-) diff --git a/32-bit-issues.md b/32-bit-issues.md index 6733b962d259bc..67d215a586c5c1 100644 --- a/32-bit-issues.md +++ b/32-bit-issues.md @@ -68,4 +68,20 @@ copy copy-msys-2.0.dll usr\bin\msys-2.0.dll usr\bin\dash.exe -c 'cd / && /usr/bin/dash.exe /usr/bin/rebaseall' ``` -These commands need to be executed in the top-level directory, and the address (0x67000000) might need to be adjusted. \ No newline at end of file +These commands need to be executed in the top-level directory, and the address (0x67000000) might need to be adjusted. + +# What's with this `Cwd.dll` problem? + +Under some circumstances, `/usr/bin/rebaseall` seems not to rebase the Perl `.dll` files "enough", and the symptom is something like this: + +``` + 1 [main] perl 297 child_info_fork::abort: address space needed by 'Cwd.dll' (0x1D0000) is already occupied +``` + +A work-around that appears to help in most of those cases is to call + +```sh +/usr/bin/rebase -b 0x63070000 /usr/lib/perl5/core_perl/auto/*/{*,*/*}.dll +``` + +Your mileage may vary: it might be necessary to play with the base address a bit. \ No newline at end of file From 3c1c674b702fccc2388d4fa79ef0538e1e19e971 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Wed, 15 Apr 2020 14:47:56 +0200 Subject: [PATCH 409/591] The latest vulnerabilities were fixed in v2.26.1 --- FAQ.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/FAQ.md b/FAQ.md index 171e561f368b5d..b5cfc495d003c0 100644 --- a/FAQ.md +++ b/FAQ.md @@ -27,7 +27,7 @@ In the meantime you could try: In general, yes: it is a good idea to stay up-to-date. -If you have a version older than 2.24.1(2), it is *highly* advisable to upgrade. A couple of Git versions came with important fixes to security-relevant vulnerabilities: 2.24.1(2), 2.17.1(2), 2.14.1, 2.7.4, 2.7.0, 2.6.1, 2.5.2, 1.9.5-preview20150319, and 1.9.5-preview20141217. +If you have a version older than 2.26.1, it is *highly* advisable to upgrade. A couple of Git versions came with important fixes to security-relevant vulnerabilities: 2.26.1, 2.24.1(2), 2.17.1(2), 2.14.1, 2.7.4, 2.7.0, 2.6.1, 2.5.2, 1.9.5-preview20150319, and 1.9.5-preview20141217. ## What is the release cadence of Git for Windows? From 1fa6b78d910b6044db220b0a82e3933f1adea26a Mon Sep 17 00:00:00 2001 From: David Macek Date: Sun, 19 Apr 2020 16:02:12 +0200 Subject: [PATCH 410/591] Fix formatting --- Visual-Studio-and-MSVC-compilation.md | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/Visual-Studio-and-MSVC-compilation.md b/Visual-Studio-and-MSVC-compilation.md index 3a1267ae74e5c0..12129881021785 100644 --- a/Visual-Studio-and-MSVC-compilation.md +++ b/Visual-Studio-and-MSVC-compilation.md @@ -16,21 +16,21 @@ The main remaining issue is to include the auto post-build steps to install the Acronyms -------- -###MSVC (Micro Soft Visual studio Compiler) +### MSVC (Micro Soft Visual studio Compiler) MSVC is used to refer to Microsoft's compiler that lies beneath the VS IDE. Exactly what is compiled, and where it is targeted depends on the normal pre-processor #defines and #includes. MSVC already includes a number of pre-defined windows library functions. -###VSyyyy IDE (Visual Studio (some year) Integrated Development Environment +### VSyyyy IDE (Visual Studio (some year) Integrated Development Environment The full windows treatment of the graphics front end which allows the navigation of your source code within its own project. -###GIT_WINDOWS_NATIVE +### GIT_WINDOWS_NATIVE This is the environment variable used to indicate that this is not a CYGWIN compilation, but that we are in Windows land. -###WIN32_LEAN_AND_MEAN +### WIN32_LEAN_AND_MEAN see https://blogs.msdn.microsoft.com/oldnewthing/20091130-00/?p=15863 This controls what additional libraries windows will import, particularly winsock which would otherwise be multiply defined. -###MSYS2 +### MSYS2 part of the (typically needed) operating stack for getting *nix / POSIX code working. see [The-difference-between-MINGW-and-MSYS2](https://github.com/git-for-windows/git/wiki/The-difference-between-MINGW-and-MSYS2) -###MinGW +### MinGW part of the (typically needed) operating stack for getting *nix / POSIX code working. see [The-difference-between-MINGW-and-MSYS2](https://github.com/git-for-windows/git/wiki/The-difference-between-MINGW-and-MSYS2) From f437e153f6aa7bb37d73de4c8eaf7451468df662 Mon Sep 17 00:00:00 2001 From: David Macek Date: Sun, 19 Apr 2020 16:18:14 +0200 Subject: [PATCH 411/591] Improve formatting and typography --- Using-sshd-to-host-a-git-server.md | 34 ++++++++++++------------------ 1 file changed, 13 insertions(+), 21 deletions(-) diff --git a/Using-sshd-to-host-a-git-server.md b/Using-sshd-to-host-a-git-server.md index 3f9928645c7c59..6c7d52bf9f0b19 100644 --- a/Using-sshd-to-host-a-git-server.md +++ b/Using-sshd-to-host-a-git-server.md @@ -1,17 +1,14 @@ Everything you need to host a git server on Windows is included with Git for Windows. -In these instructions it is assumed that Git for Windows is installed at %GIT_HOME% and that you have %GIT_HOME%\cmd in your path on both client and server machines. +In these instructions it is assumed that Git for Windows is installed at `%GIT_HOME%` and that you have `%GIT_HOME%\cmd` in your path on both client and server machines. ### Configure sshd -You need to create a key pair within %GIT_HOME%\etc\ssh for sshd to use as the server identity. -e.g., ssh_host_rsa_key and ssh_host_rsa_key.pub files +You need to create a key pair within `%GIT_HOME%\etc\ssh` for sshd to use as the server identity, e.g. `ssh_host_rsa_key` and `ssh_host_rsa_key.pub` files. -Here is a good description of how to create the key pair: - -http://www.geekride.com/how-to-generate-ssh-host-keys/ +Here is a good description of how to create the key pair: http://www.geekride.com/how-to-generate-ssh-host-keys/ ### Run sshd -A simple way to start sshd automatically when you log in is to put a .BAT script in: -%USERPROFILE%\AppData\Roaming\Microsoft\Windows\Start Menu\Programs\Startup +A simple way to start sshd automatically when you log in is to put a .BAT script in +`%USERPROFILE%\AppData\Roaming\Microsoft\Windows\Start Menu\Programs\Startup`. Mine contains: @@ -19,7 +16,7 @@ Mine contains: %GIT_HOME%\usr\bin\sshd.exe ### Test sshd -Your ultimate goal is probably to be able to ssh into the server where you are running sshd, without having to enter your password. (There are security considerations which probably require you to consult policies within your local organization) I suggest you setup your user account(s) with ssh public key authentication for this. +Your ultimate goal is probably to be able to ssh into the server where you are running sshd, without having to enter your password (there are security considerations which probably require you to consult policies within your local organization). I suggest you setup your user account(s) with ssh public key authentication for this. Start by attempting to ssh from your client to the server. Assuming this is the first time, you will be prompted with: @@ -27,9 +24,9 @@ Start by attempting to ssh from your client to the server. Assuming this is the ECDSA key fingerprint is SHA256:lZPvG6eLvsX6dRxey0ShBlYjQubifOX6yuk3atg7jQ0. Are you sure you want to continue connecting (yes/no)? -Type 'yes' and hit enter. At this moment %USERPROFILE%\\.ssh directory will be created for you, if it didn't exist already. In that directory will be a known_hosts file identifying this server as one that you trust. You should be prompted for your password at this point: Enter it in, and you should now have a remote shell on the server (Congratulations if this is your first remote shell on Windows) +Type 'yes' and hit enter. At this moment `%USERPROFILE%\.ssh` directory will be created for you, if it didn't exist already. In that directory will be a `known_hosts` file identifying this server as one that you trust. You should be prompted for your password at this point. Enter it in, and you should now have a remote shell on the server (congratulations if this is your first remote shell on Windows). -Now exit out of that shell to return to your local machine. In either a bash window or a cmd.exe window, cd to the .ssh directory found in your home directory. Type ssh-keygen and you will be prompted like this: +Now exit out of that shell to return to your local machine. In either a bash window or a cmd window, enter the `.ssh` directory found in your home directory. Type `ssh-keygen` and you will be prompted like this: Generating public/private rsa key pair. Enter file in which to save the key (/Users/yourname/.ssh/id_rsa): @@ -38,14 +35,14 @@ Now exit out of that shell to return to your local machine. In either a bash wi Depending on how physically secure your client machine is and your local security policies, you may choose to use an empty passphrase. The passphrase is used to gain access to your local key store, so if you use an empty passphrase anyone who has access to your client machine can impersonate you. -Two files will have been generated, id_rsa which contains your private key and id_rsa.pub which contains your public key. Protect your private key and never share it with anyone. Append the contents of the id_rsa.pub file generated on the client to your ~/.ssh/authorized_keys on the server (create it if it doesn't exist) +Two files will have been generated, `id_rsa` which contains your private key, and `id_rsa.pub` which contains your public key. Protect your private key and never share it with anyone. Append the contents of the `id_rsa.pub` file generated on the client to your `~/.ssh/authorized_keys` on the server (create it if it doesn't exist). At this time you should be able to ssh from the client to the server without entering a password (but if you chose a non-empty passphrase the client will prompt you for that). When a non-empty passphrase is used, there is also the option of running ssh-agent to keep the passphrase in-memory for you, but I'll not cover that here. -If you configure multiple client machines for you can copy your .ssh directory from client to client, and thus you would only need one public key in ~/.ssh/authorized_keys on the server. Just make sure you protect the contents of .ssh directory on each client. +If you configure multiple client machines for you can copy your `.ssh` directory from client to client, and thus you would only need one public key in `~/.ssh/authorized_keys` on the server (this is discouraged though). In any case, make sure you protect the contents of `.ssh` directory on each client. ### Adding projects -I create projects directly on the server in %GIT_HOME% with: +I create projects directly on the server in `%GIT_HOME%` with: `git init --bare yourproject.git` @@ -54,13 +51,8 @@ Then from a client you can clone that project and add content to it from there. Note: Creating them there is probably not ideal when it comes time to upgrading Git version on the server, so you may want to consider this before starting out. ### Connect with git -From your client machine (which may or may not be the same machine as the server) -Checkout projects via git clone with an ssh-protocol URL: - -`git clone ssh://your.server/yourproject.git` - -Or if your local username on the client is different than on the server: +From your client machine (which may or may not be the same machine as the server) checkout projects via `git clone` with an ssh-protocol URL: `git clone ssh://your.server/yourproject.git` -`git clone ssh://you@your.server/yourproject.git` +Or if your local username on the client is different than on the server: `git clone ssh://you@your.server/yourproject.git` If you have chosen to use public key authentication, you should not have to enter a password. \ No newline at end of file From 6f09d1328062259a0337bca848dc59eb6fd4a1f5 Mon Sep 17 00:00:00 2001 From: David Macek Date: Sun, 19 Apr 2020 16:22:03 +0200 Subject: [PATCH 412/591] Fix typo --- Updating-your-SDK.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Updating-your-SDK.md b/Updating-your-SDK.md index d544b99fb3d834..ce2f82576f0b24 100644 --- a/Updating-your-SDK.md +++ b/Updating-your-SDK.md @@ -2,7 +2,7 @@ The [Git for Windows SDK release](https://github.com/git-for-windows/build-extra/releases/latest) is a self extracting and auto executing 7-zip archive that clones the latest version of files in [Git for Windows SDK 64 repository](https://github.com/git-for-windows/git-sdk-64`) using a temporary bundled git. For the [32 bit version](https://github.com/git-for-windows/git-sdk-32`) it also performs a run time optimisation on cloned DLLs (rebase). -This was previously called the 'net installer', see below. It provides everything required to bootstrap a development environment, even if no git is available (or a unstable one is being worked on). +This was previously called the 'net installer', see below. It provides everything required to bootstrap a development environment, even if no git is available (or an unstable one is being worked on). It is also possible to manually extract the archive and then run `./setup-git-sdk.bat` in the MSYS2 terminal window. From 187522142b05f117d51381b25a3b6d20c995bb30 Mon Sep 17 00:00:00 2001 From: David Macek Date: Sun, 19 Apr 2020 16:29:37 +0200 Subject: [PATCH 413/591] Fix some little things --- ...d => Setting-your-Core.Editor-(e.g.-Notepad--).md | 12 ++++-------- 1 file changed, 4 insertions(+), 8 deletions(-) rename Setting-your-Core.Editor-(-e.g.-Notepad-).md => Setting-your-Core.Editor-(e.g.-Notepad--).md (81%) diff --git a/Setting-your-Core.Editor-(-e.g.-Notepad-).md b/Setting-your-Core.Editor-(e.g.-Notepad--).md similarity index 81% rename from Setting-your-Core.Editor-(-e.g.-Notepad-).md rename to Setting-your-Core.Editor-(e.g.-Notepad--).md index f8f679aee856b7..1c43e9885d0ead 100644 --- a/Setting-your-Core.Editor-(-e.g.-Notepad-).md +++ b/Setting-your-Core.Editor-(e.g.-Notepad--).md @@ -1,5 +1,5 @@ -Many Windows users are not familiar with vi/vim/emacs style command line terminal editors -[To quit: try `:q` to change out of text mode into command mode to allow the quit action]. +Many Windows users are not familiar with vi/vim/emacs style command line terminal editors. +[To quit: type `:q` in the bottom bar and press Enter. If you're typing into the file contents, press Esc first.] Many users prefer their local Windows graphic editor, such as Notepad++, this note shows how. @@ -27,9 +27,5 @@ window is closed. Some users prefer not to use the '-notabbar', as it may become a preferred option if you didn't have an Npp session already open, though the -nosession should prevent this. -The canonical discussion is at [stackoverflow/1634161](http://stackoverflow.com/questions/1634161/how-do-i-use-notepad-or-other-with-msysgit) - -Note that in Git4Windows, with its MSYS2 underpinnings, we do pass paths that are -understandable by Npp, so there should be no need for any of the cygwin path mangling trickery discussed in the SO thread. - -#Other Editor Instructions - to be added here \ No newline at end of file +The canonical discussion is at [stackoverflow/1634161](http://stackoverflow.com/questions/1634161/how-do-i-use-notepad-or-other-with-msysgit). Note that in Git for Windows, with its MSYS2 underpinnings, we do pass paths that are +understandable by Npp, so there should be no need for any of the Cygwin path mangling trickery discussed in the SO thread. From fd4aaceb3a95bf932bf508bb4d5be7a69c69b1a2 Mon Sep 17 00:00:00 2001 From: David Macek Date: Sun, 19 Apr 2020 16:29:55 +0200 Subject: [PATCH 414/591] Fix title --- ...--).md => Setting-your-Core.Editor-(e.g.-Notepad-Plus-Plus).md | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename Setting-your-Core.Editor-(e.g.-Notepad--).md => Setting-your-Core.Editor-(e.g.-Notepad-Plus-Plus).md (100%) diff --git a/Setting-your-Core.Editor-(e.g.-Notepad--).md b/Setting-your-Core.Editor-(e.g.-Notepad-Plus-Plus).md similarity index 100% rename from Setting-your-Core.Editor-(e.g.-Notepad--).md rename to Setting-your-Core.Editor-(e.g.-Notepad-Plus-Plus).md From 2b5549a770512db5f59d229f5abf2aabd0c6829b Mon Sep 17 00:00:00 2001 From: David Macek Date: Sun, 19 Apr 2020 16:38:03 +0200 Subject: [PATCH 415/591] Correct misconceptions --- Package-management.md | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/Package-management.md b/Package-management.md index 400cdc87c31843..fb84eb4d29f81d 100644 --- a/Package-management.md +++ b/Package-management.md @@ -68,26 +68,26 @@ If you want to rebuild a package, the first order of business is to know which r - [MINGW-packages](https://github.com/git-for-windows/MINGW-packages) contains the information for the MINGW packages, i.e. packages that do not require any POSIX emulation; by convention, their package name have the `mingw-w64-` prefix, and - [MSYS2-packages](https://github.com/git-for-windows/MSYS2-packages) contains the information for all packages that require a POSIX emulation, such as Bash, OpenSSH, etc. The `MSYS2-packages` repository also contains the information of the package *providing* the POSIX emulation: [`msys2-runtime`](https://github.com/git-for-windows/msys2-runtime) (see also [Building msys2-runtime](Building-msys2-runtime)). -To build MINGW packages, you need to start the appropriate *MINGW* shell (32-bit or 64-bit – this sets `MSYSTEM=MINGW32` or `MSYSTEM=MINGW64` respectively), clone the [`MINGW-packages`](https://github.com/git-for-windows/MINGW-packages) repository (recommended location: `/usr/src/MINGW-packages`), `cd` to the appropriate subdirectory and call +To build MINGW packages, you need to start the *MSYS* shell, clone the [`MINGW-packages`](https://github.com/git-for-windows/MINGW-packages) repository (recommended location: `/usr/src/MINGW-packages`), `cd` to the appropriate subdirectory and call ```bash makepkg-mingw -s ``` -(The `-s` flag tells `makepkg` that it should install dependencies automatically as needed) +(The `-s` flag tells `makepkg` that it should install dependencies automatically as needed.) -To build MSYS packages, you need to start the *MSYS* shell (e.g. `C:\git-sdk-64\msys2_shell.cmd -msys`, which sets `MSYSTEM=MSYS` before running the Bash), clone the [`MSYS2-packages`](https://github.com/git-for-windows/MSYS2-packages) repository (recommended location: `/usr/src/MSYS2-packages`), `cd` to the appropriate subdirectory and call +To build MSYS packages, you need to start the *MSYS* shell, clone the [`MSYS2-packages`](https://github.com/git-for-windows/MSYS2-packages) repository (recommended location: `/usr/src/MSYS2-packages`), `cd` to the appropriate subdirectory and call ```bash makepkg -s ``` -If you have modified any files (like `PKGBUILD`) you need to update the checksums using the `updpkgsums` command before running `makepkg` or `makepkg-mingw`. +If you have modified any source files you need to update the checksums using the `updpkgsums` command before running `makepkg` or `makepkg-mingw`. -*Note*: Before building the first MSYS package, as per [MSYS2's own documentation](https://github.com/msys2/msys2/wiki/Creating-Packages) you need to install the development packages for development: +*Note*: Before building the first package, as per [MSYS2's own documentation](https://github.com/msys2/msys2/wiki/Creating-Packages) you need to install the development packages for development: ```sh -pacman -Sy base-devel msys2-devel +pacman -Sy base-devel msys2-devel mingw-w64-x86_64-toolchain mingw-w64-i686-toolchain ``` ### Build packages from locally-patched sources From 342c2f9c2c4e8178ba486601ac426c2f329afc04 Mon Sep 17 00:00:00 2001 From: David Macek Date: Sun, 19 Apr 2020 16:38:31 +0200 Subject: [PATCH 416/591] Remove extraneous title --- OpenSSH-Integration-with-Pageant.md | 2 -- 1 file changed, 2 deletions(-) diff --git a/OpenSSH-Integration-with-Pageant.md b/OpenSSH-Integration-with-Pageant.md index 21822b8122eaa0..8537a572dbad6a 100644 --- a/OpenSSH-Integration-with-Pageant.md +++ b/OpenSSH-Integration-with-Pageant.md @@ -1,5 +1,3 @@ -# OpenSSH Integration with Pageant - For some users, it may be desirable to tie OpenSSH in to the PuTTY authentication agent (Pageant) using [ssh\-pageant](https://github.com/cuviper/ssh-pageant). This is a drop-in replacement for _ssh\-agent_, which simply builds a connection between OpenSSH and Pageant for key-based authentication. The tool makes it easy to leverage OpenSSH for remote repository access, which tends to be the most reliable choice within the specific context of Git for Windows (Git), without the need to run multiple agents which don't interoperate. This functionality became available with the release of Git 2.8.2. From f906bad4edb5c3ad48bcee391c08157817117ca8 Mon Sep 17 00:00:00 2001 From: David Macek Date: Mon, 20 Apr 2020 12:58:04 +0200 Subject: [PATCH 417/591] Recommend a MINGW shell for mingw-w64 packages --- Package-management.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/Package-management.md b/Package-management.md index fb84eb4d29f81d..c65bdbde12c5e5 100644 --- a/Package-management.md +++ b/Package-management.md @@ -68,7 +68,7 @@ If you want to rebuild a package, the first order of business is to know which r - [MINGW-packages](https://github.com/git-for-windows/MINGW-packages) contains the information for the MINGW packages, i.e. packages that do not require any POSIX emulation; by convention, their package name have the `mingw-w64-` prefix, and - [MSYS2-packages](https://github.com/git-for-windows/MSYS2-packages) contains the information for all packages that require a POSIX emulation, such as Bash, OpenSSH, etc. The `MSYS2-packages` repository also contains the information of the package *providing* the POSIX emulation: [`msys2-runtime`](https://github.com/git-for-windows/msys2-runtime) (see also [Building msys2-runtime](Building-msys2-runtime)). -To build MINGW packages, you need to start the *MSYS* shell, clone the [`MINGW-packages`](https://github.com/git-for-windows/MINGW-packages) repository (recommended location: `/usr/src/MINGW-packages`), `cd` to the appropriate subdirectory and call +To build MINGW packages, start a shell (a *MINGW* shell is recommended), clone the [`MINGW-packages`](https://github.com/git-for-windows/MINGW-packages) repository (recommended location: `/usr/src/MINGW-packages`), `cd` to the appropriate subdirectory and call ```bash makepkg-mingw -s @@ -76,7 +76,7 @@ makepkg-mingw -s (The `-s` flag tells `makepkg` that it should install dependencies automatically as needed.) -To build MSYS packages, you need to start the *MSYS* shell, clone the [`MSYS2-packages`](https://github.com/git-for-windows/MSYS2-packages) repository (recommended location: `/usr/src/MSYS2-packages`), `cd` to the appropriate subdirectory and call +To build MSYS packages, start a shell (the *MSYS* shell is recommended), clone the [`MSYS2-packages`](https://github.com/git-for-windows/MSYS2-packages) repository (recommended location: `/usr/src/MSYS2-packages`), `cd` to the appropriate subdirectory and call ```bash makepkg -s From aadcdeb37bc59ec74b916745df0b097edb2e59ec Mon Sep 17 00:00:00 2001 From: Lubas569 <52548763+lubas569@users.noreply.github.com> Date: Tue, 28 Apr 2020 14:39:48 +0100 Subject: [PATCH 418/591] Updated Symbolic Links (markdown) From e52674745c6d4fa389283d535f68b6791bad66df Mon Sep 17 00:00:00 2001 From: Viktor Szakats Date: Sun, 3 May 2020 17:38:38 +0200 Subject: [PATCH 419/591] use https --- FAQ.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/FAQ.md b/FAQ.md index b5cfc495d003c0..236cc5cb2063e2 100644 --- a/FAQ.md +++ b/FAQ.md @@ -31,7 +31,7 @@ If you have a version older than 2.26.1, it is *highly* advisable to upgrade. A ## What is the release cadence of Git for Windows? -Official Git for Windows versions mainly follow Git's release cycle: every 12 weeks or so, a new major Git version is released (see details here: http://tinyurl.com/gitCal). Typically, Git for Windows will follow suit within a day. +Official Git for Windows versions mainly follow Git's release cycle: every 12 weeks or so, a new major Git version is released (see details here: https://tinyurl.com/gitCal). Typically, Git for Windows will follow suit within a day. Other than that, Git for Windows follows the *newest* Git version's maintenance releases (read: after Git for Windows v2.15.0 was released, no new Git for Windows v2.14.x version would be released). Indicators for imminent maintenance releases of Git are: @@ -54,7 +54,7 @@ For advanced users working with the *Git for Windows* SDK `pacman` is available For hashes see https://github.com/git-for-windows/git/releases -For (G4W) release notes see the [build-extra repo](https://github.com/git-for-windows/build-extra/blob/master/ReleaseNotes.md), or the top level of your installation (e.g. [C:\Program Files\Git\ReleaseNotes.html](http://www.example.com/Program%20Files/Git/ReleaseNotes.html) - via manual browsing). +For (G4W) release notes see the [build-extra repo](https://github.com/git-for-windows/build-extra/blob/master/ReleaseNotes.md), or the top level of your installation (e.g. [C:\Program Files\Git\ReleaseNotes.html](https://www.example.com/Program%20Files/Git/ReleaseNotes.html) - via manual browsing). For extracting 7z/zip archives see [page](https://github.com/git-for-windows/git/wiki/Zip-Archives---extracting-the-released-archives). @@ -75,7 +75,7 @@ There are several methods for working around these problems: * Run programs that have problems using the [`winpty`](https://github.com/rprichard/winpty) utility. This allows you to keep using the nicer mintty terminal, but can become unwieldy if you need the workaround for many programs. * Modify the shortcut for Git Bash to run `bash` directly without `mintty` so it uses the default console host and configure it for "Quick Edit", reasonable size and scroll-back and suitable unicode font. You'll still have to live with the other quirks of console host. - * Install and use [ConEmu](http://conemu.github.io/). + * Install and use [ConEmu](https://conemu.github.io/). ## I get errors trying to check out files with long path names. Windows file paths are by default limited to 255 characters. Some repositories may have committed files which contain paths longer than the limit. By default, *Git for Windows* does not support long paths, and will print errors when trying to perform any operation on a long file name. Set the configuration property `core.longpaths` to true to allow certain Git operations to properly handle these files. See [this wiki page](https://github.com/git-for-windows/git/wiki/Git-cannot-create-a-file-or-directory-with-a-long-path) for more information. From 0e98afe49533fdd2ad1417bdbcece8006781cb52 Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Tue, 12 May 2020 16:30:12 +0100 Subject: [PATCH 420/591] Expand and clarify the review of the updates when the batch file is run. --- Updating-your-SDK.md | 13 +++++++++++-- 1 file changed, 11 insertions(+), 2 deletions(-) diff --git a/Updating-your-SDK.md b/Updating-your-SDK.md index ce2f82576f0b24..29609e3e814440 100644 --- a/Updating-your-SDK.md +++ b/Updating-your-SDK.md @@ -14,9 +14,18 @@ plus Git for Windows' packages. # Updating the installed SDK -The SDK ships with the script `update-via-pacman.bat` that you can run (but you need to make sure that all Git SDK Bash windows are closed first, i.e. that no processes are running that might lock files that want to be updated) +The SDK ships with the script `update-via-pacman.bat` that you can: + +1. Make sure that all Git SDK Bash windows are closed first, + i.e. that no processes are running that might lock files that want to be updated +1. Start a `cmd` window +1. Run `update-via-pacman.bat` in the command window +1. Review/log the changes. + +While 'double-clicking' the file in the explorer will work, the cmd window will auto-close on completion limiting you options for reviewing the updates. + +* Alternatively: -Alternatively: To keep the SDK up-to-date, periodically run pacman -Syu From 6eb897b65539e79e59c08ff11a8d1a7b69512baa Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Sat, 13 Jun 2020 20:37:20 +0100 Subject: [PATCH 421/591] extra notes on the .bat update process --- Updating-your-SDK.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/Updating-your-SDK.md b/Updating-your-SDK.md index 29609e3e814440..07f9e33e25014b 100644 --- a/Updating-your-SDK.md +++ b/Updating-your-SDK.md @@ -19,10 +19,10 @@ The SDK ships with the script `update-via-pacman.bat` that you can: 1. Make sure that all Git SDK Bash windows are closed first, i.e. that no processes are running that might lock files that want to be updated 1. Start a `cmd` window -1. Run `update-via-pacman.bat` in the command window -1. Review/log the changes. +1. Run `update-via-pacman.bat` in the command window (it will always re-install the `git-extra` package at the end) +1. Review/log the changes located in `/var/log/pacman.log`. -While 'double-clicking' the file in the explorer will work, the cmd window will auto-close on completion limiting you options for reviewing the updates. +While 'double-clicking' the file in the explorer will work, the cmd window will auto-close on completion limiting you options for reviewing the updates. Thus start a cmd window and run the .bat file from there. * Alternatively: From 184f5f2f8fbcc8431348526ee358a4a955a69b59 Mon Sep 17 00:00:00 2001 From: suntong Date: Tue, 16 Jun 2020 22:01:51 -0400 Subject: [PATCH 422/591] Updated Install inside MSYS2 proper (markdown) --- Install-inside-MSYS2-proper.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index f329e5965102e1..11599097b2e0f7 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -10,7 +10,7 @@ Note however that there are some caveats for going this way. Git for Windows cre Here the steps to take: - 1. Open an MSYS2 terminal. + 1. Open an MSYS2 terminal with `msys2_shell.cmd`. 2. Edit `/etc/pacman.conf` and just before `[mingw32]` (line #71 on my machine), add the `git-for-windows` packages repository: [git-for-windows] From b358d139afc0eb2402303d53d0f6b2d6fcecd428 Mon Sep 17 00:00:00 2001 From: suntong Date: Tue, 16 Jun 2020 22:12:33 -0400 Subject: [PATCH 423/591] Updated Install inside MSYS2 proper (markdown) --- Install-inside-MSYS2-proper.md | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index 11599097b2e0f7..cf3ee75f3d7930 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -21,6 +21,10 @@ and optionally also the MINGW-only repository for the *opposite* architecture (i [git-for-windows-mingw32] Server = https://wingit.blob.core.windows.net/i686 +If you are comfortable with command line and the `sed` command, the step 2 can be done with the following `sed` command (make sure to do proper backup before trying it): + + sed -i '/^\[mingw32\]/{ s|^|[git-for-windows]\nServer = https://wingit.blob.core.windows.net/x86-64\n\n|; }' /etc/pacman.conf + 3. Authorize signing key (this step may have to be repeated occasionally until https://github.com/msys2/msys2/issues/62 is fixed) curl -L https://raw.githubusercontent.com/git-for-windows/build-extra/master/git-for-windows-keyring/git-for-windows.gpg | From cf6719365547300b37b41d64526fedd8b0563a85 Mon Sep 17 00:00:00 2001 From: suntong Date: Tue, 16 Jun 2020 22:14:46 -0400 Subject: [PATCH 424/591] remove (this step may have to be repeated occasionally until https://github.com/msys2/msys2/issues/62 is fixed) as it is 404 now, and I don't have any problem doing it. --- Install-inside-MSYS2-proper.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index cf3ee75f3d7930..ca4542c23cf7c2 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -25,7 +25,7 @@ If you are comfortable with command line and the `sed` command, the step 2 can b sed -i '/^\[mingw32\]/{ s|^|[git-for-windows]\nServer = https://wingit.blob.core.windows.net/x86-64\n\n|; }' /etc/pacman.conf - 3. Authorize signing key (this step may have to be repeated occasionally until https://github.com/msys2/msys2/issues/62 is fixed) + 3. Authorize signing key with: curl -L https://raw.githubusercontent.com/git-for-windows/build-extra/master/git-for-windows-keyring/git-for-windows.gpg | pacman-key --add - && From 532d05b3342e149236f4ce3f3dc051cea652a6a6 Mon Sep 17 00:00:00 2001 From: suntong Date: Tue, 16 Jun 2020 22:18:44 -0400 Subject: [PATCH 425/591] Updated Install inside MSYS2 proper (markdown) --- Install-inside-MSYS2-proper.md | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index ca4542c23cf7c2..712fb0cfb22fb2 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -31,8 +31,10 @@ If you are comfortable with command line and the `sed` command, the step 2 can b pacman-key --add - && pacman-key --lsign-key 1A9F3986 - 4. Then synchronize new repository + 4. Then synchronize new repository with + pacman -Sy + # or pacboy update 5. This updates `msys2-runtime` and therefore will ask you to close the window (*not* just exit the pacman process). Don't panic, simply close all currently open MSYS2 shells and MSYS2 programs. Double-check Task Manager and kill `pacman.exe` it's still running after the window is closed, because it can linger. Once all are closed, start a new terminal again. From b2f4a75dee0e112d777ebce278bde452f0550799 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Wed, 17 Jun 2020 21:43:37 +0200 Subject: [PATCH 426/591] Use links referring to the default branch in a generic way Signed-off-by: Johannes Schindelin --- Adding-regression-tests.md | 4 ++-- FAQ.md | 6 +++--- Home.md | 2 +- How-to-participate.md | 2 +- Install-inside-MSYS2-proper.md | 2 +- ...update-inside-MSYS2,-Cygwin-or-Git-for-windows-itself.md | 2 +- Merge-Conflicts---Resolving-and-Remembering-them.md | 4 ++-- Silent-or-Unattended-Installation.md | 2 +- Technical-overview.md | 2 +- Updating-your-SDK.md | 2 +- Vagrant.md | 2 +- 11 files changed, 15 insertions(+), 15 deletions(-) diff --git a/Adding-regression-tests.md b/Adding-regression-tests.md index 9210aa727ffffe..883d31833d4ebc 100644 --- a/Adding-regression-tests.md +++ b/Adding-regression-tests.md @@ -1,4 +1,4 @@ -Git comes with an extensive regression test suite. It lives in the [`t/` subdirectory](https://github.com/git/git/tree/master/t) of the source code repository and is organized into test scripts, e.g. `t8002-blame.sh`, which contain multiple test cases. The test scripts themselves are shell scripts. +Git comes with an extensive regression test suite. It lives in the [`t/` subdirectory](https://github.com/git/git/tree/HEAD/t) of the source code repository and is organized into test scripts, e.g. `t8002-blame.sh`, which contain multiple test cases. The test scripts themselves are shell scripts. The best documentation how to add tests is the test suite itself, by example. @@ -33,7 +33,7 @@ Every script creates a test repository with a test working tree in a new directo Traditionally, the first “test case” is the setup, where you set up files and commits common to multiple test cases in the same script. -There are a bunch of really useful functions for use in test scripts, e.g. `test_commit`, which not only abbreviates the common “write a file, add it, commit it, tag the commit” stanza, but also increments the timestamp from a fixed first timestamp, so that the commits are reproducible (read: so you can reliably debug even if the bug depends on some side effect of some compression or some such). You will find a comprehensive list in [`t/README`](https://github.com/git/git/blob/master/t/README) under the “Test harness library” heading. +There are a bunch of really useful functions for use in test scripts, e.g. `test_commit`, which not only abbreviates the common “write a file, add it, commit it, tag the commit” stanza, but also increments the timestamp from a fixed first timestamp, so that the commits are reproducible (read: so you can reliably debug even if the bug depends on some side effect of some compression or some such). You will find a comprehensive list in [`t/README`](https://github.com/git/git/blob/HEAD/t/README) under the “Test harness library” heading. There are also a bunch of useful test helpers in `t/helper/` (automatically added to the `PATH`) e.g. `test-chmtime`. If you need to test native functions, you can introduce a new test helper, or piggy-back onto an existing one. diff --git a/FAQ.md b/FAQ.md index 236cc5cb2063e2..da3c22a38ebf69 100644 --- a/FAQ.md +++ b/FAQ.md @@ -14,7 +14,7 @@ More information here: [Git for Windows' prerequisites](https://gitforwindows.or There is currently no MSI package; there is an exe installer and a portable package. You are welcome to contribute a Pull Request that packages a new installer. -~There is an existing Pull Request in development and looking for testers, please try out https://github.com/robmen/gitsetup/issues/1 and give feedback.~ It's closed by now. Future development is happening [here](https://github.com/git-for-windows/build-extra/tree/master/msi/). +~There is an existing Pull Request in development and looking for testers, please try out https://github.com/robmen/gitsetup/issues/1 and give feedback.~ It's closed by now. Future development is happening [here](https://github.com/git-for-windows/build-extra/tree/HEAD/msi/). In the meantime you could try: @@ -54,7 +54,7 @@ For advanced users working with the *Git for Windows* SDK `pacman` is available For hashes see https://github.com/git-for-windows/git/releases -For (G4W) release notes see the [build-extra repo](https://github.com/git-for-windows/build-extra/blob/master/ReleaseNotes.md), or the top level of your installation (e.g. [C:\Program Files\Git\ReleaseNotes.html](https://www.example.com/Program%20Files/Git/ReleaseNotes.html) - via manual browsing). +For (G4W) release notes see the [build-extra repo](https://github.com/git-for-windows/build-extra/blob/HEAD/ReleaseNotes.md), or the top level of your installation (e.g. [C:\Program Files\Git\ReleaseNotes.html](https://www.example.com/Program%20Files/Git/ReleaseNotes.html) - via manual browsing). For extracting 7z/zip archives see [page](https://github.com/git-for-windows/git/wiki/Zip-Archives---extracting-the-released-archives). @@ -114,7 +114,7 @@ Ensure also that you are using proper Build Tools (v140). It's going by default ## Licenses -Reproduced from [Git for Windows' release notes](https://github.com/git-for-windows/build-extra/blob/master/ReleaseNotes.md#licenses): +Reproduced from [Git for Windows' release notes](https://github.com/git-for-windows/build-extra/blob/HEAD/ReleaseNotes.md#licenses): 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. diff --git a/Home.md b/Home.md index 9c9fc18251a29f..feaa70a40d1209 100644 --- a/Home.md +++ b/Home.md @@ -18,7 +18,7 @@ And yes, the idea is still the same as the original one: Update the _MSYS2_ setu Now, keep in mind that _MSYS2_ and Linux (The original target for _Git_'s distribution) are very different beasts. Their distributions might include packages that are built from the same source code (i.e. the `binutils`, `gcc` or `bash` package), but the runtime is very, very different: _MSYS2_'s runtime is a stripped-down, slightly modified _Cygwin_ runtime running on top of the Windows kernel, while Linux' runtime is the Linux kernel, running as a separate OS altogether. -So if you are missing some packages - feel free to start making one. This is Open Source, after all, so everybody interested and capable enough can contribute whatever they need to address their needs. And that includes you: you could imitate e.g. [a simple `PKGBUILD` file](https://github.com/Alexpux/MINGW-packages/blob/master/mingw-w64-assimp-git/PKGBUILD) to build a new package e.g. `msmtp`, the component that _Git for Windows_ 1.x uses to support `sendemail`. Then open a Pull Request so that _Git for Windows_ can ship it. Our documentation will be helpful in that endeavor: [package-management](https://github.com/git-for-windows/git/wiki/Package-management), in particular [package-management#rebuild-packages](https://github.com/git-for-windows/git/wiki/Package-management#rebuild-packages). +So if you are missing some packages - feel free to start making one. This is Open Source, after all, so everybody interested and capable enough can contribute whatever they need to address their needs. And that includes you: you could imitate e.g. [a simple `PKGBUILD` file](https://github.com/msys2/MINGW-packages/blob/HEAD/mingw-w64-assimp-git/PKGBUILD) to build a new package e.g. `msmtp`, the component that _Git for Windows_ 1.x uses to support `sendemail`. Then open a Pull Request so that _Git for Windows_ can ship it. Our documentation will be helpful in that endeavor: [package-management](https://github.com/git-for-windows/git/wiki/Package-management), in particular [package-management#rebuild-packages](https://github.com/git-for-windows/git/wiki/Package-management#rebuild-packages). # Start documenting If you need inspiration what you could write about: document your common work flows. Write a tutorial how to start coding _Git for Windows_, how to run the test suite. Write a tutorial how to debug a failing test. Write about something you would have wished you had known about Git for Windows a long time ago. diff --git a/How-to-participate.md b/How-to-participate.md index 3321fad5557b09..18136d74b349cf 100644 --- a/How-to-participate.md +++ b/How-to-participate.md @@ -10,7 +10,7 @@ A lot of documentation wants to be written, still. A good place is [the Git for # Fix bugs or add features in the Git code itself -Download [the SDK](https://gitforwindows.org/#download-sdk) and build Git. See the [CONTRIBUTING.md](https://github.com/git-for-windows/git/blob/master/CONTRIBUTING.md) page/file +Download [the SDK](https://gitforwindows.org/#download-sdk) and build Git. See the [CONTRIBUTING.md](https://github.com/git-for-windows/git/blob/HEAD/CONTRIBUTING.md) page/file Also have a look at [this page](https://github.com/git-for-windows/git/wiki/Building-Git) for tips and tricks revolving around building and debugging Git. diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index 712fb0cfb22fb2..8b17b306af1e12 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -27,7 +27,7 @@ If you are comfortable with command line and the `sed` command, the step 2 can b 3. Authorize signing key with: - curl -L https://raw.githubusercontent.com/git-for-windows/build-extra/master/git-for-windows-keyring/git-for-windows.gpg | + curl -L https://raw.githubusercontent.com/git-for-windows/build-extra/HEAD/git-for-windows-keyring/git-for-windows.gpg | pacman-key --add - && pacman-key --lsign-key 1A9F3986 diff --git a/Install-or-update-inside-MSYS2,-Cygwin-or-Git-for-windows-itself.md b/Install-or-update-inside-MSYS2,-Cygwin-or-Git-for-windows-itself.md index 5e0df05173bb01..5c132923b198fb 100644 --- a/Install-or-update-inside-MSYS2,-Cygwin-or-Git-for-windows-itself.md +++ b/Install-or-update-inside-MSYS2,-Cygwin-or-Git-for-windows-itself.md @@ -4,7 +4,7 @@ Instead of configuring and installing Git for Windows using `pacman`, this guide ## How to -With the script `getgit` introduced by [git-for-windows/build-extra#261](https://github.com/git-for-windows/build-extra/pull/261), you can download and run the script or just run `curl https://raw.githubusercontent.com/git-for-windows/build-extra/master/git-extra/getgit | bash`. +With the script `getgit` introduced by [git-for-windows/build-extra#261](https://github.com/git-for-windows/build-extra/pull/261), you can download and run the script or just run `curl https://raw.githubusercontent.com/git-for-windows/build-extra/HEAD/git-extra/getgit | bash`. The script would gather information about the current system ( *Msys / Cygwin* ), bitness, version of an already existed Git for Windows, version of the latest released Git for Windows... and then forge a proper download URL targeting a proper version of the `PortableGit` installer. With all the information prepared, the script would download the installer and unpack it to `/tmp`. After that, all the necessary files will be copied to a proper place inside the ( *Msys's / Cygwin's* ) file system without touching any existing **non-git-for-windows-exclusive** files. diff --git a/Merge-Conflicts---Resolving-and-Remembering-them.md b/Merge-Conflicts---Resolving-and-Remembering-them.md index 78c3d94c025e1a..f04d3dcdd08ebe 100644 --- a/Merge-Conflicts---Resolving-and-Remembering-them.md +++ b/Merge-Conflicts---Resolving-and-Remembering-them.md @@ -11,7 +11,7 @@ The documentation is terse, so let's also point to some on-line articles: * [Fun with rerere](https://gitster.livejournal.com/41795.html) from the Git maintainer * [Fix conflicts only once with git rerere](https://medium.com/@porteneuve/fix-conflicts-only-once-with-git-rerere-7d116b2cec67) Nice graphs and examples. * [Do you even rerere?](https://blog.theodo.fr/2015/01/do-you-even-rerere/) Good discussion, including `rerere-train`. -* [rerere-train.sh](https://github.com/git/git/blob/master/contrib/rerere-train.sh) use the 'blame' button for extra commit info. +* [rerere-train.sh](https://github.com/git/git/blob/HEAD/contrib/rerere-train.sh) use the 'blame' button for extra commit info. * [Are there any downsides to enabling git rerere?](https://stackoverflow.com/q/5519244/717355) Not really, but read and learn. * [Smarter rebase avoiding redundant work?](https://stackoverflow.com/q/10601541/717355) more rerere-train answers * [7.9 Git Tools (book) - Rerere](https://git-scm.com/book/en/v2/Git-Tools-Rerere). @@ -29,7 +29,7 @@ Threads about the internal workings: [saving and replaying multiple variants with rerere](https://public-inbox.org/git/1442275050-30497-1-git-send-email-gitster@pobox.com/) 2015-09-14 [Should rerere auto-update a merge resolution?](https://public-inbox.org/git/CACPiFCJH7RSb_rz6M6ADuGi0q+oeWYhE1fNMQC0EUcCn_kCJwg@mail.gmail.com/) 2017-08-23 [rebase: use OPT_RERERE_AUTOUPDATE()](https://public-inbox.org/git/20190319190317.6632-4-phillip.wood123@gmail.com/#r) 2019-03-19 -[git/Documentation/technical/rerere.txt](https://github.com/git/git/blob/master/Documentation/technical/rerere.txt) committed on 5 Aug 2018 +[git/Documentation/technical/rerere.txt](https://github.com/git/git/blob/HEAD/Documentation/technical/rerere.txt) committed on 5 Aug 2018 [git rerere unresolve file](https://public-inbox.org/git/200911211958.40872.j6t@kdbg.org/) 2009-11-21 patch series [Make git-rerere a builtin](https://public-inbox.org/git/Pine.LNX.4.63.0612201738000.19693@wbgn013.biozentrum.uni-wuerzburg.de/) 2006-12-20 convert from a perl script [Add a test for git-rerere](https://public-inbox.org/git/Pine.LNX.4.63.0612201737190.19693@wbgn013.biozentrum.uni-wuerzburg.de/) 2006-12-20 diff --git a/Silent-or-Unattended-Installation.md b/Silent-or-Unattended-Installation.md index 3dde95798a0a32..7ce1dc5eaa9147 100644 --- a/Silent-or-Unattended-Installation.md +++ b/Silent-or-Unattended-Installation.md @@ -8,7 +8,7 @@ An example of this is Git-2.12.2.2-64-bit.exe /VERYSILENT /NORESTART /NOCANCEL /SP- /CLOSEAPPLICATIONS /RESTARTAPPLICATIONS /COMPONENTS="icons,ext\reg\shellhere,assoc,assoc_sh" ``` -You can find all of the possible flags to use by calling the installer with the `/?` flag (for the options supported by InnoSetup out of the box), and by inspecting the [`install.iss` file](https://github.com/git-for-windows/build-extra/blob/master/installer/install.iss) (for custom options added only to Git for Windows' installer). +You can find all of the possible flags to use by calling the installer with the `/?` flag (for the options supported by InnoSetup out of the box), and by inspecting the [`install.iss` file](https://github.com/git-for-windows/build-extra/blob/HEAD/installer/install.iss) (for custom options added only to Git for Windows' installer). You can also load install parameters from a file with `/LOADINF="filename"`, and you can record parameters to a file using `/SAVEINF="filename"`. diff --git a/Technical-overview.md b/Technical-overview.md index 662de031bc5430..baa751fc9b91b6 100644 --- a/Technical-overview.md +++ b/Technical-overview.md @@ -24,7 +24,7 @@ Afterwards you need to install git to make these changes available to the instal If you made any documentation changes, you need to install the documentation too: `make install-html && prefix=/mingw64 make -C contrib/subtree install-html` (the second make invocation installs the `git-subtree.html` which is otherwise missing and leads to an error by the portable installer). -In some cases, the change you want to make is not in git itself, but in the additional files needed to emulate the *ix environment git expects (things like `grep`, `find`, `cat`,...), or in additional helper files (e.g. `start-ssh-agent.cmd`). These files come from [Msys](https://github.com/git-for-windows/MSYS2-packages) and [Mingw](https://github.com/git-for-windows/MINGW-packages) packages. Please see the documentation for how to make [changes to these packages](Package-management#technical-details). Some files are also in the `build-extras` repo in the subdir [`git-extra`](https://github.com/git-for-windows/build-extra/tree/master/git-extra) (the script which calls notepad as a commit message editor, diff filter for word files,...). The source code for these files are also under `/usr/src` but need to be checked out first (e.g. `cd /usr/src/MINGW-packages && git fetch && git checkout master`). +In some cases, the change you want to make is not in git itself, but in the additional files needed to emulate the *ix environment git expects (things like `grep`, `find`, `cat`,...), or in additional helper files (e.g. `start-ssh-agent.cmd`). These files come from [Msys](https://github.com/git-for-windows/MSYS2-packages) and [Mingw](https://github.com/git-for-windows/MINGW-packages) packages. Please see the documentation for how to make [changes to these packages](Package-management#technical-details). Some files are also in the `build-extras` repo in the subdir [`git-extra`](https://github.com/git-for-windows/build-extra/tree/HEAD/git-extra) (the script which calls notepad as a commit message editor, diff filter for word files,...). The source code for these files are also under `/usr/src` but need to be checked out first (e.g. `cd /usr/src/MINGW-packages && git fetch && git checkout master`). # Building an installer diff --git a/Updating-your-SDK.md b/Updating-your-SDK.md index 07f9e33e25014b..5a6a5bd62d5c9a 100644 --- a/Updating-your-SDK.md +++ b/Updating-your-SDK.md @@ -56,7 +56,7 @@ update. * [makepkg man page](https://www.archlinux.org/pacman/makepkg.8.html) * ArchLinux articles - [Creating Packages](https://wiki.archlinux.org/index.php/Creating_packages) and [PKGBuild](https://wiki.archlinux.org/index.php/PKGBUILD) * [MSYS2 Introduction & Contributing](http://sourceforge.net/p/msys2/wiki/Contributing%20to%20MSYS2/) -* [SDK's setup-git-sdk.bat script](https://github.com/git-for-windows/build-extra/blob/master/sdk-installer/setup-git-sdk.bat) +* [SDK's setup-git-sdk.bat script](https://github.com/git-for-windows/build-extra/blob/HEAD/sdk-installer/setup-git-sdk.bat) ## Origin of 'net installer' concept diff --git a/Vagrant.md b/Vagrant.md index a6d920886ebd27..29df28dc6fafad 100644 --- a/Vagrant.md +++ b/Vagrant.md @@ -18,7 +18,7 @@ To compile and install Git, you will have to run `make clean` first because *Git # Alternative to the Git SDK way -If you cannot download and install the Git SDK for some reason or other, you could also clone [the Git source code](https://github.com/git-for-windows/git) using [Git for Windows](https://gitforwindows.org/) instead, but make sure that Unix line endings are used: `git clone -c core.autocrlf=false https://github.com/git-for-windows/git vagrant-git`. If Git for Windows does not even work for you, you could also download the source code [as a `.zip`](https://github.com/git-for-windows/git/archive/master.zip) and unpack it. +If you cannot download and install the Git SDK for some reason or other, you could also clone [the Git source code](https://github.com/git-for-windows/git) using [Git for Windows](https://gitforwindows.org/) instead, but make sure that Unix line endings are used: `git clone -c core.autocrlf=false https://github.com/git-for-windows/git vagrant-git`. If Git for Windows does not even work for you, you could also download the source code [as a `.zip`](https://github.com/git-for-windows/git/archive/HEAD.zip) and unpack it. After that, continue with the `vagrant up` step above. From 999817d91cddf2b5ec0cb002e88b0d53fff87a1f Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Wed, 17 Jun 2020 21:46:28 +0200 Subject: [PATCH 427/591] Adjust for the currently-used main branch name Signed-off-by: Johannes Schindelin --- Building-msys2-runtime.md | 2 +- Compiling-Git-with-Visual-Studio.md | 4 ++-- ...ation,-Executable-bit-and-file-modes,-core.FileMode.md | 2 +- Making-a-portable-Git.md | 2 +- Making-an-installer.md | 2 +- Rebasing-Git-for-Windows.md | 8 ++++---- ...l-code-viewer-and-linkage-to-Visual-Studio,-for-Git.md | 2 +- Technical-overview.md | 8 ++++---- 8 files changed, 15 insertions(+), 15 deletions(-) diff --git a/Building-msys2-runtime.md b/Building-msys2-runtime.md index ad03aa0ec3bd9a..714d0dd180c785 100644 --- a/Building-msys2-runtime.md +++ b/Building-msys2-runtime.md @@ -8,7 +8,7 @@ 2. Install the MSYS2 Toolchain: `pacman -S msys2-devel base-devel`. -3. Initialize the local MSYS2-packages clone: `cd /usr/src/MSYS2-packages && git fetch origin && git checkout master`. +3. Initialize the local MSYS2-packages clone: `cd /usr/src/MSYS2-packages && git fetch origin && git checkout main`. 4. Change to the `msys2-runtime` directory: `cd msys2-runtime` diff --git a/Compiling-Git-with-Visual-Studio.md b/Compiling-Git-with-Visual-Studio.md index 94474aaa2e8c85..dab51fdd129cc3 100644 --- a/Compiling-Git-with-Visual-Studio.md +++ b/Compiling-Git-with-Visual-Studio.md @@ -1,10 +1,10 @@ Please note: this page describes how to compile Git's source code in Visual Studio 2015 or later. -# Checking out `vs/master` +# Checking out `vs/main` Git's source code (and hence also Git for Windows' source code) is [usually built using GNU C and GNU Make in a Git for Windows SDK](https://github.com/git-for-windows/git/wiki/Building-Git). -However, as of Git for Windows v2.11.0, a much more convenient way is available: by cloning https://github.com/git-for-windows/git and checking out the `vs/master` branch, you will automatically have project definitions ready to go with Visual Studio. +However, as of Git for Windows v2.11.0, a much more convenient way is available: by cloning https://github.com/git-for-windows/git and checking out the `vs/main` branch, you will automatically have project definitions ready to go with Visual Studio. Simply open the `git.sln` file and build the solution. DO NOT upgrade Build Tools to v141 - it will not work. If you are using VS 2017 or later, you need to install Build Tools v140 manually. diff --git a/File-names,-Branch-names,-Path-quotation,-Executable-bit-and-file-modes,-core.FileMode.md b/File-names,-Branch-names,-Path-quotation,-Executable-bit-and-file-modes,-core.FileMode.md index bbbcbd71daa69d..299508a3f213c0 100644 --- a/File-names,-Branch-names,-Path-quotation,-Executable-bit-and-file-modes,-core.FileMode.md +++ b/File-names,-Branch-names,-Path-quotation,-Executable-bit-and-file-modes,-core.FileMode.md @@ -6,7 +6,7 @@ In addition Git branch names are stored as filenames. This means that in normal usage, Git will have difficulty when it meets a changed case file or branch. Lower case is common for Linux usage! -E.g. `Master` branch and `master` branch are different, even though, on Windows, Git will often mistake one for the other (because Windows will read the 'other' case version of the file. +E.g. `Main` branch and `main` branch are different, even though, on Windows, Git will often mistake one for the other (because Windows will read the 'other' case version of the file. Likewise Windows will not be able to check out both an upper case and lower case version of a file(s). Apparently the vim repository has this 'two versions' Vim/vim problem. diff --git a/Making-a-portable-Git.md b/Making-a-portable-Git.md index 3021f7f90e165d..e8431f0be8d711 100644 --- a/Making-a-portable-Git.md +++ b/Making-a-portable-Git.md @@ -5,7 +5,7 @@ To package the portable Git, install the [SDK](https://gitforwindows.org/#downlo ```bash cd /usr/src/build-extra git fetch -git checkout master +git checkout main ./portable/release.sh -test ``` diff --git a/Making-an-installer.md b/Making-an-installer.md index 4dc6b439db1ac9..6c95f202a1337e 100644 --- a/Making-an-installer.md +++ b/Making-an-installer.md @@ -28,7 +28,7 @@ then issue the following commands: ```bash cd /usr/src/build-extra -git pull master +git pull main ./installer/release.sh -test ``` diff --git a/Rebasing-Git-for-Windows.md b/Rebasing-Git-for-Windows.md index 50b6e744ad6db1..0a6483241b519c 100644 --- a/Rebasing-Git-for-Windows.md +++ b/Rebasing-Git-for-Windows.md @@ -3,7 +3,7 @@ To do a *rebase* of the *Git for Windows* source onto a new [upstream](https://g # Assumptions 1. You want to *rebase* onto a new [upstream](https://github.com/git/git) release tagged as `v2.3.4` 2. The latest *rebase* was done onto a [upstream](https://github.com/git/git) release tagged as `v2.3.3` -3. the `origin/master` below means remote https://github.com/git-for-windows/git, its `master` branch. +3. the `origin/main` below means remote https://github.com/git-for-windows/git, its `main` branch. You may have them named differently. # Preconditions @@ -11,7 +11,7 @@ To do a *rebase* of the *Git for Windows* source onto a new [upstream](https://g 2. A fetched build-extra repository. `cd /usr/src/build-extra` `git fetch` - `git checkout master` + `git checkout main` (`git pull` if your branch is behind the upstream) 3. Working directory set to current *Git for Windows* source. `cd /usr/src/git` @@ -33,9 +33,9 @@ Note: the `merging-rebase` argument is a special placeholder that is interpreted # Verifying the *rebase* 1. Generate a *diff* of the previous state. - `git diff v2.3.3..origin/master > prev.diff` + `git diff v2.3.3..origin/main > prev.diff` 2. Generate a *diff* of the current state. - `git diff v2.3.4..master > curr.diff` + `git diff v2.3.4..main > curr.diff` 3. *Diff* the *diffs*. `git diff --no-index prev.diff curr.diff` diff --git a/Sourcetrail-code-viewer-and-linkage-to-Visual-Studio,-for-Git.md b/Sourcetrail-code-viewer-and-linkage-to-Visual-Studio,-for-Git.md index 780b91fcebe41a..fd365ebf13c215 100644 --- a/Sourcetrail-code-viewer-and-linkage-to-Visual-Studio,-for-Git.md +++ b/Sourcetrail-code-viewer-and-linkage-to-Visual-Studio,-for-Git.md @@ -2,7 +2,7 @@ This note is a quick start to setting up a Sourcetrail project for exploring the Git source code in conjunction with Visual Studio. Source trail is configurable and some parameter need to be set on initial project setup. -1. Git-for-Windows is available as a Visual Studio .sln in the `vs/master` [branch](https://github.com/git-for-windows/git/tree/vs/master) . It comprise ~19 sub-projects including `git` and `libgit`. +1. Git-for-Windows is available as a Visual Studio .sln in the `vs/main` [branch](https://github.com/git-for-windows/git/tree/vs/main) . It comprises ~19 sub-projects including `git` and `libgit`. 2. This was tested with the free VS2017 community edition. 3. Build the solution(.sln) in Visual Studio so that it's `vcpkg` dependencies are downloaded and compiled (may take some time). 4. Download and install the Sourcetrail software. Check the [documentation](https://www.sourcetrail.com/documentation/), especially the [intro video](https://youtu.be/7fguPwKR_7Y). diff --git a/Technical-overview.md b/Technical-overview.md index baa751fc9b91b6..835ffc1dfe798d 100644 --- a/Technical-overview.md +++ b/Technical-overview.md @@ -8,7 +8,7 @@ The process to build an instance of the Git for Windows installer is made easier # Installing the SDK -Download the [SDK](https://gitforwindows.org/#download-sdk) and run it (using "Run as Administrator"). You will end up with a console window running the `Git for Windows SDK` shell, which you can use for the next steps. You need to fetch the latest version of the Git sources - just run the command `sdk init git`. After that, if you just want to build an installer from latest master, you are ready to go. +Download the [SDK](https://gitforwindows.org/#download-sdk) and run it (using "Run as Administrator"). You will end up with a console window running the `Git for Windows SDK` shell, which you can use for the next steps. You need to fetch the latest version of the Git sources - just run the command `sdk init git`. After that, if you just want to build an installer from the latest development, you are ready to go. You can open the `Git for Windows SDK` shell by double clicking `git-bash.exe` in the install folder. @@ -16,7 +16,7 @@ As the installer is made by putting together files from the Git for Windows SDK, # Hacking on git -If you only want an installer of the latest version of git (master), then you can skip this step. +If you only want an installer of the latest development version of git, then you can skip this step. The sources of git are checked out in `/usr/src/git`. [Hack in (and test)](Building-Git) the changes you want... @@ -24,7 +24,7 @@ Afterwards you need to install git to make these changes available to the instal If you made any documentation changes, you need to install the documentation too: `make install-html && prefix=/mingw64 make -C contrib/subtree install-html` (the second make invocation installs the `git-subtree.html` which is otherwise missing and leads to an error by the portable installer). -In some cases, the change you want to make is not in git itself, but in the additional files needed to emulate the *ix environment git expects (things like `grep`, `find`, `cat`,...), or in additional helper files (e.g. `start-ssh-agent.cmd`). These files come from [Msys](https://github.com/git-for-windows/MSYS2-packages) and [Mingw](https://github.com/git-for-windows/MINGW-packages) packages. Please see the documentation for how to make [changes to these packages](Package-management#technical-details). Some files are also in the `build-extras` repo in the subdir [`git-extra`](https://github.com/git-for-windows/build-extra/tree/HEAD/git-extra) (the script which calls notepad as a commit message editor, diff filter for word files,...). The source code for these files are also under `/usr/src` but need to be checked out first (e.g. `cd /usr/src/MINGW-packages && git fetch && git checkout master`). +In some cases, the change you want to make is not in git itself, but in the additional files needed to emulate the *ix environment git expects (things like `grep`, `find`, `cat`,...), or in additional helper files (e.g. `start-ssh-agent.cmd`). These files come from [Msys](https://github.com/git-for-windows/MSYS2-packages) and [Mingw](https://github.com/git-for-windows/MINGW-packages) packages. Please see the documentation for how to make [changes to these packages](Package-management#technical-details). Some files are also in the `build-extras` repo in the subdir [`git-extra`](https://github.com/git-for-windows/build-extra/tree/HEAD/git-extra) (the script which calls notepad as a commit message editor, diff filter for word files,...). The source code for these files are also under `/usr/src` but need to be checked out first (e.g. `cd /usr/src/MINGW-packages && git fetch && git checkout main`). # Building an installer @@ -37,7 +37,7 @@ As a one time step, you need to prepare the extra files which contain the helper ```bash cd /usr/src/build-extra git fetch -git checkout master +git checkout main ``` The next step depends on whether you want a normal setup-based installer or a portable installer: From 40efc18ab72886d04638000b9077aa78ce531390 Mon Sep 17 00:00:00 2001 From: David Macek Date: Fri, 19 Jun 2020 23:28:03 +0200 Subject: [PATCH 428/591] Replace pacboy commands with pacman --- Install-inside-MSYS2-proper.md | 12 +++++------- 1 file changed, 5 insertions(+), 7 deletions(-) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index 8b17b306af1e12..97658deba76ac2 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -4,7 +4,7 @@ **This guide assumes that you want the 64-bit version of Git for Windows.** -Git for Windows being based on MSYS2, it's possible to install the `git` package into an existing MSYS2 installation. That means that if you are already using MSYS2 on your computer, you can use Git for Windows without running the full installer or using the portable version. +Git for Windows being based on MSYS2, it's possible to install the `mingw-w64-git` package into an existing MSYS2 installation. That means that if you are already using MSYS2 on your computer, you can use Git for Windows without running the full installer or using the portable version. Note however that there are some caveats for going this way. Git for Windows created some patches for `msys2-runtime` that have not been sent upstream. (This had been planned, but it was determined in issue [#284](/git-for-windows/git/issues/284) that it would probably not be happening.) This means that you have to install Git for Windows customized `msys2-runtime` to have a fully working `git` inside MSYS2. @@ -29,22 +29,20 @@ If you are comfortable with command line and the `sed` command, the step 2 can b curl -L https://raw.githubusercontent.com/git-for-windows/build-extra/HEAD/git-for-windows-keyring/git-for-windows.gpg | pacman-key --add - && - pacman-key --lsign-key 1A9F3986 + pacman-key --lsign-key 3B6D86A1BA7701CD0F23AED888138B9E1A9F3986 4. Then synchronize new repository with - pacman -Sy - # or - pacboy update + pacman -Syu 5. This updates `msys2-runtime` and therefore will ask you to close the window (*not* just exit the pacman process). Don't panic, simply close all currently open MSYS2 shells and MSYS2 programs. Double-check Task Manager and kill `pacman.exe` it's still running after the window is closed, because it can linger. Once all are closed, start a new terminal again. 6. Then synchronize *again* (updating the non-core part of the packages): - pacboy update + pacman -Su 7. And finally install the Git/cURL packages: - pacboy sync git:x git-doc-html:x git-doc-man:x git-extra: curl:x + pacman -S mingw-w64-x86_64-{git,git-doc-html,git-doc-man,curl} git-extra 8. Finally, check that everything went well by doing `git --version` in a MINGW64 shell and it should output something like `git version 2.14.1.windows.1` (or newer). From b76ebd779549fc3dedd70bd1e8a5ac5ef529755c Mon Sep 17 00:00:00 2001 From: David Macek Date: Sun, 21 Jun 2020 18:05:00 +0200 Subject: [PATCH 429/591] Changed `-Syu` to `-Syyu`; not sure if needed, but it one report suggests that --- Install-inside-MSYS2-proper.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index 97658deba76ac2..152d9725f08e53 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -33,7 +33,7 @@ If you are comfortable with command line and the `sed` command, the step 2 can b 4. Then synchronize new repository with - pacman -Syu + pacman -Syyu 5. This updates `msys2-runtime` and therefore will ask you to close the window (*not* just exit the pacman process). Don't panic, simply close all currently open MSYS2 shells and MSYS2 programs. Double-check Task Manager and kill `pacman.exe` it's still running after the window is closed, because it can linger. Once all are closed, start a new terminal again. From ab6260a90cc3f7513c0a1df56e9eee9c3bf6596b Mon Sep 17 00:00:00 2001 From: David Macek Date: Sun, 21 Jun 2020 18:42:14 +0200 Subject: [PATCH 430/591] Open a MINGW64 shell as a separate step --- Install-inside-MSYS2-proper.md | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index 152d9725f08e53..d9046027c1b012 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -45,4 +45,6 @@ If you are comfortable with command line and the `sed` command, the step 2 can b pacman -S mingw-w64-x86_64-{git,git-doc-html,git-doc-man,curl} git-extra - 8. Finally, check that everything went well by doing `git --version` in a MINGW64 shell and it should output something like `git version 2.14.1.windows.1` (or newer). + 8. Close the current shell and open a MINGW64 shell (`msys2_shell.cmd -mingw64`). + + 9. Finally, check that everything went well by doing `git --version` and it should output something like `git version 2.14.1.windows.1` (or newer). From a51f93204dc3d1257339aae6b7319221397aef06 Mon Sep 17 00:00:00 2001 From: David Macek Date: Sun, 21 Jun 2020 18:44:40 +0200 Subject: [PATCH 431/591] Change `-u` to `-uu` to enable downgrades --- Install-inside-MSYS2-proper.md | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index d9046027c1b012..d55eaf2189eb1a 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -33,13 +33,15 @@ If you are comfortable with command line and the `sed` command, the step 2 can b 4. Then synchronize new repository with - pacman -Syyu + pacman -Syyuu 5. This updates `msys2-runtime` and therefore will ask you to close the window (*not* just exit the pacman process). Don't panic, simply close all currently open MSYS2 shells and MSYS2 programs. Double-check Task Manager and kill `pacman.exe` it's still running after the window is closed, because it can linger. Once all are closed, start a new terminal again. + It might happen that the packages are downgrades. This is unfortunate but if you want the authentic Git for Windows experience, it's necessary. + 6. Then synchronize *again* (updating the non-core part of the packages): - pacman -Su + pacman -Suu 7. And finally install the Git/cURL packages: From 7259685b732234247fb4dafc931f6386f5ad9f13 Mon Sep 17 00:00:00 2001 From: David Macek Date: Sun, 21 Jun 2020 18:45:11 +0200 Subject: [PATCH 432/591] Fix indentation of step 2 --- Install-inside-MSYS2-proper.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index d55eaf2189eb1a..7d7f3863255b86 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -16,12 +16,12 @@ Here the steps to take: [git-for-windows] Server = https://wingit.blob.core.windows.net/x86-64 -and optionally also the MINGW-only repository for the *opposite* architecture (i.e. MINGW32 for 64-bit SDK): + and optionally also the MINGW-only repository for the *opposite* architecture (i.e. MINGW32 for 64-bit SDK): [git-for-windows-mingw32] Server = https://wingit.blob.core.windows.net/i686 -If you are comfortable with command line and the `sed` command, the step 2 can be done with the following `sed` command (make sure to do proper backup before trying it): + If you are comfortable with command line and the `sed` command, the step 2 can be done with the following `sed` command (make sure to do proper backup before trying it): sed -i '/^\[mingw32\]/{ s|^|[git-for-windows]\nServer = https://wingit.blob.core.windows.net/x86-64\n\n|; }' /etc/pacman.conf From 4395438b898f78bc1fb4d0d4e69b1a46330c324d Mon Sep 17 00:00:00 2001 From: David Macek Date: Sun, 21 Jun 2020 18:49:40 +0200 Subject: [PATCH 433/591] Provide support for the installation steps --- Install-inside-MSYS2-proper.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index 7d7f3863255b86..686bc290a318c8 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -1,6 +1,6 @@ # **Please note that this scenario is not officially supported by Git for Windows** -(The reason this is unsupported is that there are no volunteers to support that scenario.) +If you need help with the installation steps, you can contact @Elieux on the `git-for-windows/git` Gitter room or on the `#msys2` IRC channel. Please don't file issues with Git for Windows installed this way until you verify them in an official Git for Windows distribution. **This guide assumes that you want the 64-bit version of Git for Windows.** From 89160be13d9deb6dfd4382789f6af9b31ace6151 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Tue, 30 Jun 2020 13:53:00 +0200 Subject: [PATCH 434/591] At long last, taking some time to write all of this down --- Releasing-Git-for-Windows.md | 109 +++++++++++++++++++++++++++++++++++ 1 file changed, 109 insertions(+) create mode 100644 Releasing-Git-for-Windows.md diff --git a/Releasing-Git-for-Windows.md b/Releasing-Git-for-Windows.md new file mode 100644 index 00000000000000..53b6a22e8e6584 --- /dev/null +++ b/Releasing-Git-for-Windows.md @@ -0,0 +1,109 @@ +The release process of Git for Windows is ever-evolving. For now, it consists of these steps: + +- Making sure that there are no unaddressed issues +- Rebasing Git for Windows' patches +- Opening a PR to kick off a PR build (and waiting for it to succeed) +- Kicking off the "Git Artifacts" Azure Pipeline +- Verifying that the resulting installer works +- Kicking off the Azure Release Pipeline that publishes the release +- Pushing directly to `main` to close the PR and set the stage for the Azure Pipeline (at some stage during the `-rc` cycle) + +Note: the hardest part is traditonally preparing `-rc0` of every major release. + +# Making sure that there are no unaddressed issues + +There are essentially three-and-a-half venues where Git for Windows bugs are reported: + +- The Git for Windows bug tracker at https://github.com/git-for-windows/git/issues +- The Git for Windows mailing list at https://groups.google.com/forum/#!forum/git-for-windows +- The Git mailing list at https://public-inbox.org/git/ +- Twitter. Yep: ugh. Git for Windows is actually that popular that a couple of its users seriously think that Twitter would make for a perfectly fine way to report bugs. As if 280 characters were enough to make for a good bug report. Therefore, sometimes, when the Git for Windows maintainer feels particularly masochistic, they go to https://twitter.com/search?q=%23git-for-windows and see whether there is any valid bug report (one really has to pick out the needles between all that hay). + +# Rebasing Git for Windows' patches + +Note: this section assumes that the reader is _very_ familiar with interactive rebases, in particular with the `--rebase-merges` variant thereof. Readers without much experience in this are highly advised to read up on https://git-scm.com/docs/git-rebase#_rebasing_merges before going any further. + +The trick is not just to run `/usr/src/build-extra/shears.sh --merging --onto merging-rebase`, it is even more important to verify that the result makes sense. To make sense, the result: + +- Should not have any `fixup!`/`squash!` commits +- Should have the already-submitted and easily-submittable patches contained within the `ready-for-upstream` "sub thicket" (i.e. the patches/patch series that are merged at the top, via the `Merge branch "ready-for-upstream"` commit. +- In general, the commit topology should reflect the structure + - Ready for upstream + - Still in flux/not yet cleaned up enough + - Never to be contributed to Git (e.g. Git for Windows' very own adjustments to README.md) +- Should be verified via `git range-diff` to the previous release, to make sure that no important patches were lost. + + The Git for Windows maintainer likes to use a custom alias for that: + + ```ini + [alias] + gfw-range-diff = "!sh -c 'a=; while case \"$1\" in -*) a=\"${a:+$a }$1\";; *) break;; esac; do shift; done; git range-diff --creation-factor=95 $a \"$1^{/^Start.the.merging-rebase}..$1\" \"$2^{/^Start.the.merging-rebase}..$2\"' -" + ``` + + With this alias, one can conveniently generate that range-diff. For example, after rebasing Git for Windows to v2.28.0, `git gfw-range-diff v2.27.0.windows.1 HEAD | clip.exe` would generate the range-diff and put it into the clipboard, ready to paste into the PR. +- To make extra certain that nothing important has been lost, call `git diff .. >prev` for the previous Git version, then `git diff .. >cur` and compare with `git diff --no--index prev cur`, looking for lines starting with two diff markers (`/^[-+][-+]` in `less.exe`). + +Note: internally, the `shears.sh` script runs `git rebase --rebase-merges --interactive` with one quirk: a first line is injected into the todo list that creates a "dummy" merge commit: it is a merge that pulls in the pre-rebase commits, but it uses `-s ours` so that the tree remains unchanged relative to the onto commit. The effect is that the patches got rebased, _and_ the end result still fast-forwards from the previous tip of the main branch. + +# Opening a PR to kick off a PR build + +This is easy: just push a branch to your fork and then go to https://github.com/git-for-windows/git/pull/new/main and select that branch from your fork. + +The harder part is to include the range-diff (with `--creation-factor=95`; see the `gfw-range-diff` alias in the previous section) and discuss it. + +To make it easier to see what happened to patches that are no longer part of Git for Windows' branch thicket, it is highly advised to use a variant of the shell script used in https://github.com/git-for-windows/git/pull/2626, and to perform a similarly thorough analysis, especially for any `-rc0` version: + +```sh +$ x="$(git range-diff -s origin/main^{/^Start.the}..origin/main v2.27.0..v2.28.0-rc0 | + sed -n 's/^[ 0-9]*: \([0-9a-f][0-9a-f]*\) [=!] [ 0-9]*: \([0-9a-f][0-9a-f]*\).*/-e "s\/\1\/\1 (upstream: \2)\/"/p')" + +$ git gfw-range-diff origin/main HEAD | + sed -e 's/^[ 0-9]*: [0-9a-f]* [=!]/ &/' \ + -e 's/^[ 0-9]*: [0-9a-f]* /+&/' | + eval sed $x | + clip.exe +``` + +# Kicking off the "Git Artifacts" Azure Pipeline + +Direct your browser to https://dev.azure.com/git-for-windows/git/_build?definitionId=34&_a=summary and queue a new build ("Run pipeline") with the build variable `use.branch` set to something like `rebase-to-v2.27.0@https://github.com/dscho/git` and `Branch/tag` set to the PR's tip commit (e.g. `refs/pull/2645/head`). + +That will pull down the PR branch of https://github.com/git-for-windows/git (technically, this is not necessary, because `use.branch` will make sure that the correct branch is used, but it makes the output nicer, as the Azure Pipeline will then show the correct commit in the summary), then look at the tags of https://github.com/git/git to determine the name of the new tag (read: the upcoming Git for Windows version), then fetch `main` of https://github.com/git-for-windows/build-extra, use the latter's `ReleaseNotes.md` to generate the message for the new tag, and then generate: + +- The 32-bit/64-bit installers +- The 32-bit/64-bit Portable Gits +- The 32-bit/64-bit `.tar.bz2` archives +- The 32-bit/64-bit MinGits +- The 32-bit/64-bit BusyBox-based MinGits +- The NuGet packages (both full and minimal version) + +and publish them as a build artifact. + +# Verifying that the resulting installer works + +The idea here is to download the `Git--64-bit.exe` artifact from the Pipeline, install it, and run through the "pre-flight check list" at https://github.com/git-for-windows/build-extra/blob/HEAD/installer/checklist.txt. + +# Kicking off the Azure Release Pipeline that publishes the release + +This one is _really_ easy (as long as nothing is broken...): https://dev.azure.com/git-for-windows/git/_release?definitionId=1&_a=releases + +Sadly, things are broken a lot. In those cases, the logs have to be analyzed, and the Pipeline needs to be edited (when it asks whether you want to edit for this release only, do say that you want that), and the deployment has to be restarted. Examples for failures that happened in the past: + +- Timeouts while uploading the GitHub Release. In that case, the partially-populated draft release has to be deleted manually (first delete the assets, or it won't delete the release), and then re-deploy. + +- Outage of github.com. In that case, simply re-deploying the stage that pushes the commits was sufficient. + +- Something was pushed to the `main` branch in the meantime, and the Release Pipeline could not handle that. In this instance, the Pipeline was edited to `git pull && git push` if the `git push` failed. More complex scenarios might involve pulling a branch from a personal fork, e.g. if merge conflicts had to be resolved. + +# Pushing directly to `main` to close the PR and set the stage for the Azure Pipeline + +This step is trivial: `git push origin main` + +Note: traditionally, we do _not_ do that for `-rc0` releases, as they typically happen something like two-and-a-half weeks before the final release, and in rare cases we might need the flexibility to allow for a _real_ quick release (e.g. if a security vulnerability was not disclosed responsibly). The idea going forward, however, is to push to `main` relatively soon after the Release Pipeline finished, to keep the Pacman repository, the [snapshots](https://wingit.blob.core.windows.net/files/index.html) and the `main` branches as aligned as possible. + +# How to release a quick-fix release + +Outside of the `-rc` phase, just follow the process as described above. This will publish one of those `(2)` versions, e.g. v2.24.1(2). Typically this happens _very_ close after an official release e.g. when really serious bugs crept into Git for Windows unnoticed, such as Git GUI crashing before even showing the window. + +In the hypothetical case that a quick-fix release is necessary during the `-rc` phase, _after_ `main` was pushed, i.e. needing to branch off of an earlier revision of `main`, all the above steps can be performed with ease (as the Pipelines do not run directly on `main`, but instead require `use.branch` to be set). The only tricky part is pushing the result to `main`. The recommended way is to use the next merging rebase to pull in the changes by inserting another fake merge before the one inserted by `shears.sh`. \ No newline at end of file From 1c3b090da92c48ce5b809e37fd2f12869e8da7ff Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Thu, 2 Jul 2020 11:36:34 +0200 Subject: [PATCH 435/591] Document Git for Windows' snapshots --- "Git-for-Windows'-\"snapshots\".md" | 9 +++++++++ 1 file changed, 9 insertions(+) create mode 100644 "Git-for-Windows'-\"snapshots\".md" diff --git "a/Git-for-Windows'-\"snapshots\".md" "b/Git-for-Windows'-\"snapshots\".md" new file mode 100644 index 00000000000000..d27a65357a06b4 --- /dev/null +++ "b/Git-for-Windows'-\"snapshots\".md" @@ -0,0 +1,9 @@ +Git for Windows' `main` branch is kept in an always-releasable state as much as possible. + +For example, in case that a critical bug is discovered that really needs to be fixed within the same day, Git for Windows does not have a maintenance branch (or, "stable" branch). Such a fix would be applied on top of `main` and a new version would be created from that state. + +To allow users to help verifying that "always-releasable state", as well as to allow users to verify fixes introduced via PRs, Git for Windows builds "snapshot" releases (published [here](https://wingit.blob.core.windows.net/files/index.html)) whenever the `main` branch advances. + +Those snapshot releases are considered robust. They are built using [the exact same Azure Pipeline](https://dev.azure.com/git-for-windows/git/_build?definitionId=34&_a=summary) that also builds official Git for Windows versions (as well as the `-rc` pre-releases leading up to every major version). Snapshot versions come in the same flavors as full Git for Windows versions: 32-bit and 64-bit, installers, portable Gits, MinGits. + +Snapshot versions are signed the same way as full Git for Windows versions, too. Apart from the version number and from the fact that they are not uploaded as [full GitHub Releases](github.com/git-for-windows/git/releases), they are pretty much indistinguishable from official Git for Windows versions. \ No newline at end of file From 31525f780a2ebe8d6609bb2a9360a978fc09fbb4 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Fri, 3 Jul 2020 15:28:03 +0200 Subject: [PATCH 436/591] Explain the role of the "Git wrapper" --- "The-\"Git-wrapper\".md" | 31 +++++++++++++++++++++++++++++++ 1 file changed, 31 insertions(+) create mode 100644 "The-\"Git-wrapper\".md" diff --git "a/The-\"Git-wrapper\".md" "b/The-\"Git-wrapper\".md" new file mode 100644 index 00000000000000..172f518a7469b1 --- /dev/null +++ "b/The-\"Git-wrapper\".md" @@ -0,0 +1,31 @@ +One of the more confusing aspects of Git for Windows is that its main entry points (`\git-bash.exe`, `\cmd\git.exe`, `\bin\bash.exe`, where `` is the location into which Git was installed, typically `C:\Program Files\Git`) are _not_ the actual binaries implementing the functionality. + +All of these executables are variants of the ["Git wrapper"](https://github.com/git-for-windows/MINGW-packages/blob/main/mingw-w64-git/git-wrapper.c). Its only purpose is to set a couple of environment variables and then spawn the _actual_ program. For example, `Git/bin/bash.exe` will set `MSYSTEM` and `PATH` and spawn `Git/usr/bin/bash.exe`. + +# Why is this needed? + +The actual programs, e.g. `bash.exe` or `git.exe`, live in `\usr\bin` and `\mingw64\bin` (or `\mingw32\bin` in 32-bit setups), and the issue is that either links dynamically to some `.dll` files (e.g. `msys-2.0.dll`). So if we were to add those directories to the `PATH` variable, 3rd-party software that links _to the same_ `.dll` files would quite possibly be broken (or Git's own programs). Even worse, some of the other `.dll` files present in those folders are in much more widespread use, e.g. OpenSSL. This has been the cause for quite a few tickets in the past, and the `\cmd` directory was added to help this, at first having Batch scripts for `git`, `git-gui` and `gitk`, and later those were turned into Visual Basic scripts, but eventually we just bit the bullet and turned them into real executables because we needed more control than scripts allowed us (e.g. to prevent ugly console windows from "flashing"). + +# What environment variables are overridden by the Git wrapper? + +- **`PATH`** + + First of all, the `PATH` variable is modified, so that Git's own `bin` folders come first. This is needed e.g. to ensure that those Git commands that are still implemented as Unix shell scripts find the expected commands (`find.exe`, for example, which is a namesake of `C:\Windows\system32\find.exe`, but the latter has a very different purpose from the [POSIX `find`](https://pubs.opengroup.org/onlinepubs/009695399/utilities/find.html) expected by Git). + +- **`HOME`** + + The next-important environment variable which the Git wrapper ensures exists is `HOME`, following Git's expectations that that variable exists and points to the current user's home directory. It is unfortunately not quite trivial to figure out what is the correct value for this (find out about some challenges e.g. in [this ticket](https://github.com/git-for-windows/git/issues/2709), demonstrating that `USERPROFILE` is not always the best answer). + +- **`MSYSTEM`** + + To accommodate Git's expectations where it assumes e.g. a Unix shell to be present on the `PATH`, Git for Windows ships with a subset of [MSYS2](https://msys2.github.io/) (find out about more historical context [here](https://github.com/git-for-windows/git/wiki#about)). MSYS2 can be run in two flavors, [MINGW and MSYS](https://github.com/git-for-windows/git/wiki/The-difference-between-MINGW-and-MSYS2) and the flavor Git for Windows needs is MINGW. This is specified via the `MSYSTEM` variable. + +- **`PLINK_PROTOCOL`** + + While [Plink](https://the.earth.li/~sgtatham/putty/0.74/htmldoc/Chapter7.html#plink) does not enjoy first-class support in Git for Windows (the much-preferred solution is to use the included OpenSSH client), for historical reasons, Git for Windows offers support for it when an existing Plink configuration is detected. To avoid Plink from thinking that it should use the `telnet` protocol instead of the `ssh` protocol, we set `PLINK_PROTOCOL` (unless it is already defined). + +For full information, read the source code of [the `setup_environment()` function of the Git wrapper](https://github.com/git-for-windows/MINGW-packages/blob/0a7407a39c3015cc7a3c296d8a0db38439c65eed/mingw-w64-git/git-wrapper.c#L116-L200). + +# Avoiding the Git wrapper + +Especially when running scripts that call Git tens of thousands of times, the start-up cost for the Git wrapper might be noticed, and users might want to side-step it. To address this desire, starting with https://github.com/git-for-windows/git/pull/2506 Git for Windows supports the use case the hard-coded absolute path to `\mingw64\bin\git.exe` is used to launch Git, without the need to add it to the `PATH`. \ No newline at end of file From 257aaabb590a49fa949cab50a1275ac47d7d9d93 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Mon, 6 Jul 2020 17:02:49 +0200 Subject: [PATCH 437/591] Start documenting how Git for Windows' components are upgraded to new versions in the SDK --- Building-new-package-versions.md | 23 +++++++++++++++++++++++ 1 file changed, 23 insertions(+) create mode 100644 Building-new-package-versions.md diff --git a/Building-new-package-versions.md b/Building-new-package-versions.md new file mode 100644 index 00000000000000..d4758a18457414 --- /dev/null +++ b/Building-new-package-versions.md @@ -0,0 +1,23 @@ +As described in [Package management](Package-management), Git for Windows' SDK is a close derivative of the [MSYS2](https://msys2.github.io/) system, and as such, its components are built using `makepkg` and `makepkg-mingw` (borrowed from Arch Linux' [`pacman`](https://wiki.archlinux.org/index.php/Pacman)). + +Most of those packages are actually built by the MSYS2 project and consumed by Git for Windows. However, a couple of components (including cURL and OpenSSH) _are_ built by Git for Windows, e.g. to be able to react faster to newly-available versions, or to allow for modifications specific to Git for Windows. + +In general, the process to upgrade components to new versions is quite tedious. + +First of all, the Git for Windows maintainer needs to be aware that a new version of a Git for Windows SDK component is available. The current process for this involves using a custom IFTTT applet to receive notifications when, say, [cURL's Atom feed](https://github.com/curl/curl/tags.atom) reports a new version. + +The next step is to update the package definitions (i.e. Pacman's [`PKGBUILD`](https://www.archlinux.org/pacman/PKGBUILD.5.html) files), to reflect the new version and the checksum for the respective archive. + +Git for Windows offers some automation for that, figuring out the current version of a specified component in [its administrative script called `please.sh`](https://github.com/git-for-windows/build-extra/blob/master/please.sh) and updating the respective `PKGBUILD`, then building and uploading the Pacman package. The idea is to call e.g. `sdk cd build-extra && ./please.sh upgrade curl` to upgrade cURL. + +This script is, essentially, the backbone of the two Azure Pipelines used by the Git for Windows project to build new package versions: [Build and publish MINGW Pacman package](https://dev.azure.com/git-for-windows/git/_build?definitionId=32) and [Build and publish MSYS Pacman package](https://dev.azure.com/git-for-windows/git/_build?definitionId=33). + +However, many a time this automation fails, for a variety of reasons, including, but not limited to: + +- Download links do change. If this is the case, the `source` definition in the `PKGBUILD` needs to be adjusted. +- Patches that are applied as part of the `build` function in the `PKGBUILD` script might no longer apply to newer versions (see below). +- Spurious network errors. Those are the maintainer's favorite hiccups. + +# Adjusting patches when they no longer apply to new versions + +TBD \ No newline at end of file From 95e14087e22840cbec81e05f12a805cc7e34adf7 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Tue, 7 Jul 2020 09:54:14 +0200 Subject: [PATCH 438/591] Document the main challenge with the `perl` package --- Upgrading-the-`perl`-component-to-a-new-version.md | 13 +++++++++++++ 1 file changed, 13 insertions(+) create mode 100644 Upgrading-the-`perl`-component-to-a-new-version.md diff --git a/Upgrading-the-`perl`-component-to-a-new-version.md b/Upgrading-the-`perl`-component-to-a-new-version.md new file mode 100644 index 00000000000000..ff966095805346 --- /dev/null +++ b/Upgrading-the-`perl`-component-to-a-new-version.md @@ -0,0 +1,13 @@ +One of the many components included in Git for Windows' SDK is the `perl` package. Upgrading to a new Perl version is unfortunately a bit more involved than only following the advice in [Building new package versions](Building-new-package-versions). In addition to adjusting the patches applied via the `PKGBUILD` script, the major problem with Perl is that its DLL embeds the Perl version in its file name. + +As a consequence, _all_ native Perl modules are broken immediately after upgrading to a new major Perl version. As far as Git for Windows is concerned, the affected components are: + +- subversion +- perl-Net-SSLeay +- perl-HTML-Parser +- perl-TermReadKey +- perl-Locale-Gettext +- perl-XML-Parser +- perl-YAML-Syck + +Therefore, immediately after a successful upgrade of the `perl` component to a new major Perl version (as of time of writing, the most recent such upgrade was to v5.32.0), these components have to be rebuilt, typically by forcing an incremented `pkgrel`. \ No newline at end of file From 4a4918414287b43d94c2dc5c12b5faf0a8195cd8 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Tue, 7 Jul 2020 09:58:47 +0200 Subject: [PATCH 439/591] Link the two new pages that go into further detail --- Package-management.md | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/Package-management.md b/Package-management.md index c65bdbde12c5e5..0e52ed23e16260 100644 --- a/Package-management.md +++ b/Package-management.md @@ -129,3 +129,8 @@ perl -MCPAN -e shell Pacman repositories are served via HTTP, as static files in a single directory. The most important file in that directory is the *package index*, called `.db.tar.xz` by convention. This package index can be updated via `repo-add ...` (this updated *only* the package index, it does *not* copy the package files into the same directory). Pacman expects to find the package files referenced in the package index in the same directory as the index. The *Git for Windows*-specific packages are served by [Azure Blob Storage](https://azure.microsoft.com/en-us/services/storage/blobs/), see below. We ship MSYS2 and MINGW packages for two architectures, `i686` and `x86_64`. Pacman is configured to use these in `/etc/pacman.conf`. + +# Further reading + +- [Building new package versions](Building-new-package-versions) +- [Upgrading the `perl` component to a new version](Upgrading-the-%60perl%60-component-to-a-new-version) \ No newline at end of file From 56a862f881d3afd6c0d3eaee0b2066b9582ee63e Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Tue, 7 Jul 2020 10:08:03 +0200 Subject: [PATCH 440/591] Add the motivation for keeping Perl up to date --- Upgrading-the-`perl`-component-to-a-new-version.md | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/Upgrading-the-`perl`-component-to-a-new-version.md b/Upgrading-the-`perl`-component-to-a-new-version.md index ff966095805346..a43a3114da340c 100644 --- a/Upgrading-the-`perl`-component-to-a-new-version.md +++ b/Upgrading-the-`perl`-component-to-a-new-version.md @@ -1,4 +1,6 @@ -One of the many components included in Git for Windows' SDK is the `perl` package. Upgrading to a new Perl version is unfortunately a bit more involved than only following the advice in [Building new package versions](Building-new-package-versions). In addition to adjusting the patches applied via the `PKGBUILD` script, the major problem with Perl is that its DLL embeds the Perl version in its file name. +One of the many components included in Git for Windows' SDK is the `perl` package. Part of its components are included in Git for Windows' installer and Portable Git versions, to allow for running Perl scripts. The two most prominent Perl scripts in Git for Windows are, of course, `git svn` and `git send-email`. + +Upgrading to a new Perl version is unfortunately a bit more involved than only following the advice in [Building new package versions](Building-new-package-versions). In addition to adjusting the patches applied via the `PKGBUILD` script, the major problem with Perl is that its DLL embeds the Perl version in its file name. As a consequence, _all_ native Perl modules are broken immediately after upgrading to a new major Perl version. As far as Git for Windows is concerned, the affected components are: From c3ae3f104a4fe76cd262dff0d568a1215fd94e44 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Tue, 7 Jul 2020 13:20:28 +0200 Subject: [PATCH 441/591] Mention that the DLL file name has to be upgraded manually (don't ask me how I found out -- again -- that this is a manual step) --- Upgrading-the-`perl`-component-to-a-new-version.md | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/Upgrading-the-`perl`-component-to-a-new-version.md b/Upgrading-the-`perl`-component-to-a-new-version.md index a43a3114da340c..969e4db96029a6 100644 --- a/Upgrading-the-`perl`-component-to-a-new-version.md +++ b/Upgrading-the-`perl`-component-to-a-new-version.md @@ -2,7 +2,13 @@ One of the many components included in Git for Windows' SDK is the `perl` packag Upgrading to a new Perl version is unfortunately a bit more involved than only following the advice in [Building new package versions](Building-new-package-versions). In addition to adjusting the patches applied via the `PKGBUILD` script, the major problem with Perl is that its DLL embeds the Perl version in its file name. -As a consequence, _all_ native Perl modules are broken immediately after upgrading to a new major Perl version. As far as Git for Windows is concerned, the affected components are: +# Making sure that the DLL has the correct version in its file name + +This is important, and it is a manual step required on top of [the usual adjustments to the patches](https://github.com/git-for-windows/git/wiki/Building-new-package-versions#adjusting-patches-when-they-no-longer-apply-to-new-versions): In the [`PKGBUILD`](https://github.com/msys2/MSYS2-packages/blob/HEAD/perl/PKGBUILD file, the line `-Dlibperl=msys-perl5_.dll` needs to be adjusted. + +# Rebuilding dependencees + +As a consequence of the version name being embedded in the DLL's file name, _all_ native Perl modules are broken immediately after upgrading to a new major Perl version. As far as Git for Windows is concerned, the affected components are: - subversion - perl-Net-SSLeay From c975f2e45c8d108d930e89a1cf077f68afc410a3 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Tue, 7 Jul 2020 13:45:18 +0200 Subject: [PATCH 442/591] Explain how to deal with no-longer-applicable patches --- Building-new-package-versions.md | 19 ++++++++++++++++++- 1 file changed, 18 insertions(+), 1 deletion(-) diff --git a/Building-new-package-versions.md b/Building-new-package-versions.md index d4758a18457414..83641c6d36762b 100644 --- a/Building-new-package-versions.md +++ b/Building-new-package-versions.md @@ -20,4 +20,21 @@ However, many a time this automation fails, for a variety of reasons, including, # Adjusting patches when they no longer apply to new versions -TBD \ No newline at end of file +The way `makepkg` works is unfortunately not very integrated with Git (as it was invented _before_ Git), therefore the way it works is to specify the URL to the archive (or to the branch in a repository) as `source`, together with any patches needed to compile it in MSYS2. The archive will be unpacked in the `src/` directory automatically, but the patches need to be applied specifically as part of the `prepare` step in the `PKGBUILD`. + +When these patches no longer apply after upgrading to a newer version of the component, it can be a challenge to fix that. + +The strategy that worked best for the Git for Windows maintainer goes like this: + +1. initialize a new Git repository in `src/playground` +2. use `/usr/src/git/contrib/fast-import/import-tars.perl` to import the _previous_ version (i.e. the one where the patches still apply) +3. create a new branch from the import tag (`git switch -c rebase-to- import-tars`) +4. if the patches are actually in mbox format, they can be imported using `git am ../../*.patch`; otherwise they need to be manually applied and committed (something like `srcdir=../..; grep "patch -p" $srcdir/PKGBUILD | while read line; do patch="${line##*/}" && eval "$line" && git commit -m "$patch" || break; done`) +5. import the new version using `import-tars.perl` +6. create a new branch from the current one (`git switch -c rebase-to-`) +7. rebase the patches (`git rebase -i --onto - -`) +8. export the patches (if they were in mbox format, `git format-patch - -o ../..`, otherwise a variation of `for commit in $(git rev-list HEAD); do patch="$(git show -s --format=%s $commit)" && git diff $commit^! >../../"$patch" || break; done`) +9. test (`cd ../.. && sdk build`) +10. commit, push (and open a PR unless pushing directly to `main`) + +Caveat: this strategy needs manual adjustments if the archive in question contains files with DOS line endings (I am looking at you, [Perl](https://github.com/git-for-windows/git/wiki/Upgrading-the-%60perl%60-component-to-a-new-version) _shakes fist_): `import-tars.perl` will happily import those verbatim, but the `bsdtar` used by `makepkg` to unpack the archive will convert them to Unix line endings, and if the patches expect DOS line endings, they won't apply. \ No newline at end of file From 9f3b627e17f7aa90e7230b76b9ba42ae97457c29 Mon Sep 17 00:00:00 2001 From: Derrick Stolee Date: Tue, 7 Jul 2020 08:23:07 -0400 Subject: [PATCH 443/591] typo with link --- Upgrading-the-`perl`-component-to-a-new-version.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Upgrading-the-`perl`-component-to-a-new-version.md b/Upgrading-the-`perl`-component-to-a-new-version.md index 969e4db96029a6..74838dd6787c7e 100644 --- a/Upgrading-the-`perl`-component-to-a-new-version.md +++ b/Upgrading-the-`perl`-component-to-a-new-version.md @@ -4,7 +4,7 @@ Upgrading to a new Perl version is unfortunately a bit more involved than only f # Making sure that the DLL has the correct version in its file name -This is important, and it is a manual step required on top of [the usual adjustments to the patches](https://github.com/git-for-windows/git/wiki/Building-new-package-versions#adjusting-patches-when-they-no-longer-apply-to-new-versions): In the [`PKGBUILD`](https://github.com/msys2/MSYS2-packages/blob/HEAD/perl/PKGBUILD file, the line `-Dlibperl=msys-perl5_.dll` needs to be adjusted. +This is important, and it is a manual step required on top of [the usual adjustments to the patches](https://github.com/git-for-windows/git/wiki/Building-new-package-versions#adjusting-patches-when-they-no-longer-apply-to-new-versions): In the [`PKGBUILD`](https://github.com/msys2/MSYS2-packages/blob/HEAD/perl/PKGBUILD) file, the line `-Dlibperl=msys-perl5_.dll` needs to be adjusted. # Rebuilding dependencees From 59a2f28deaea78532bdd8125f8f3d09fc2bfb169 Mon Sep 17 00:00:00 2001 From: David Macek Date: Thu, 10 Sep 2020 19:58:07 +0200 Subject: [PATCH 444/591] Mention a work-around for broken git-add--interactive --- Install-inside-MSYS2-proper.md | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index 686bc290a318c8..d1003ec52b09b4 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -50,3 +50,7 @@ Here the steps to take: 8. Close the current shell and open a MINGW64 shell (`msys2_shell.cmd -mingw64`). 9. Finally, check that everything went well by doing `git --version` and it should output something like `git version 2.14.1.windows.1` (or newer). + +#### Troubleshooting + +If you encounter error "*error: wrong number of arguments, should be from 1 to 2*" with `git add -p`, set `add.interactive.useBuiltin` to `true`. From e118ff4154fa267b400279034cf1c52b9268695d Mon Sep 17 00:00:00 2001 From: Affaway <70744022+Affaway@users.noreply.github.com> Date: Wed, 14 Oct 2020 03:22:52 -0700 Subject: [PATCH 445/591] Updated Issue reporting guidelines (markdown) --- Issue-reporting-guidelines.md | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/Issue-reporting-guidelines.md b/Issue-reporting-guidelines.md index c9114763529b84..9a51f1555784d7 100644 --- a/Issue-reporting-guidelines.md +++ b/Issue-reporting-guidelines.md @@ -1,6 +1,9 @@ -* Search the existing [open](https://github.com/git-for-windows/git/issues?q=is%3Aopen) and [closed](https://github.com/git-for-windows/git/issues?q=is%3Aclosed) issues. Maybe the bug was already reported? -* Include the output of `git --version` and the Windows version. In case the issue might depend on the server include its git version and Windows version also. Of course, if you use a 32-bit Windows or 32-bit Git on a 64-bit Windows, you really want to mention that, too. -* Mention what options you chose when installing Git for Windows, what console window you use (if any), anything that will make it easier to understand what exactly you tried. +# BEGIN HERE +*Search Existing issues & pull requests: +* [Open](https://github.com/git-for-windows/git/issues?q=is%3Aopen) and [closed](https://github.com/git-for-windows/git/issues?q=is%3Aclosed) issues. +*Determine weather or not a bug report has been dispatched. What is the status of the report? Are there any other bugs to be looked at? If so issue another bug report. +* Include the output of the ___git--version___ in addition to the Windows version as sometimes problems arise that are directly dependent on the physical hardware type of server being used. Notating the git/ Windows version is super important to resolving the issues at times. Likewise, please mention your usage of 32-bit Windows &/Or 32-bit Git on a 64-bit Windows ectara. The more info the better. It's better to over do it than leave a lot of guess work! :) +* Detail the option choice(S) used when installing Git for Windows, console type/window (if any). The goal is excellent communication. Think of it like you're trying to explain your process to a child using clear, simple, precise notes to help us understand your method and findings. Prevents ha * If your setup is different from "normal" setups in any way, it is a good idea to put specifics about that into your bug report, too. * Describe your issue properly. If you spend 30 seconds throwing out a sloppy report, do expect that others will spend exactly the same amount on trying to resolve it. In contrast, if you write a complete and pleasantly informative bug report, you will almost certainly be rewarded by excellent help with your problem. * Include a [Minimal, Complete, and Verifiable example](http://stackoverflow.com/help/mcve) using GitHub Markdown's `codeblock` delimiters. From 71c4a99a1f4a7ae21573ae248981a7d46c2ee04f Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Mon, 19 Oct 2020 15:58:54 +0100 Subject: [PATCH 446/591] add Building-new-package-versions --- 0.-Index.md | 1 + 1 file changed, 1 insertion(+) diff --git a/0.-Index.md b/0.-Index.md index 2a82202aabf271..00b0a06c595ede 100644 --- a/0.-Index.md +++ b/0.-Index.md @@ -6,6 +6,7 @@ This is for the poor souls in corporate IE environments who can't expand the pag * [Auto launching ssh agent when git starts](https://github.com/git-for-windows/git/wiki/Auto-launching-ssh-agent-when-git-starts) * [Building Git](https://github.com/git-for-windows/git/wiki/Building-Git) * [Building msys2 runtime](https://github.com/git-for-windows/git/wiki/Building-msys2-runtime) +* [Building new package versions](https://github.com/git-for-windows/git/wiki/Building-new-package-versions) * [Compiling Git with Visual Studio](https://github.com/git-for-windows/git/wiki/Compiling-Git-with-Visual-Studio) * [Contact](https://github.com/git-for-windows/git/wiki/Contact) * [Continuous Integration (CI)](https://github.com/git-for-windows/git/wiki/Continuous-Integration-(CI)) From 5997f57d96b29de901fee1aa634564a5cc04bae2 Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Mon, 19 Oct 2020 16:00:10 +0100 Subject: [PATCH 447/591] add exec()-semantics --- 0.-Index.md | 1 + 1 file changed, 1 insertion(+) diff --git a/0.-Index.md b/0.-Index.md index 00b0a06c595ede..7a7a074d8af6ee 100644 --- a/0.-Index.md +++ b/0.-Index.md @@ -12,6 +12,7 @@ This is for the poor souls in corporate IE environments who can't expand the pag * [Continuous Integration (CI)](https://github.com/git-for-windows/git/wiki/Continuous-Integration-(CI)) * [Debugging Git](https://github.com/git-for-windows/git/wiki/Debugging-Git) * [Diagnosing performance issues](https://github.com/git-for-windows/git/wiki/Diagnosing-performance-issues) +* [exec() semantics](https://github.com/git-for-windows/git/wiki/exec()-semantics) * [FAQ](https://github.com/git-for-windows/git/wiki/FAQ) * [File names, Branch names, Path quotation, Executable bit and file modes, core.FileMode](https://github.com/git-for-windows/git/wiki/File-names,-Branch-names,-Path-quotation,-Executable-bit-and-file-modes,-core.FileMode) * [fork(), exec(), CreateProcess(): Windows vs Linux](https://github.com/git-for-windows/git/wiki/Windows-vs-Linux-fork()/exec()-semantics) From 0bb509845a3f072eaacababd86d8e41686aab70f Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Mon, 19 Oct 2020 16:02:34 +0100 Subject: [PATCH 448/591] added Git-for-Windows' "snapshots" --- 0.-Index.md | 1 + 1 file changed, 1 insertion(+) diff --git a/0.-Index.md b/0.-Index.md index 7a7a074d8af6ee..25cb40fd2229a1 100644 --- a/0.-Index.md +++ b/0.-Index.md @@ -17,6 +17,7 @@ This is for the poor souls in corporate IE environments who can't expand the pag * [File names, Branch names, Path quotation, Executable bit and file modes, core.FileMode](https://github.com/git-for-windows/git/wiki/File-names,-Branch-names,-Path-quotation,-Executable-bit-and-file-modes,-core.FileMode) * [fork(), exec(), CreateProcess(): Windows vs Linux](https://github.com/git-for-windows/git/wiki/Windows-vs-Linux-fork()/exec()-semantics) * [Git cannot create a file or directory with a long path](https://github.com/git-for-windows/git/wiki/Git-cannot-create-a-file-or-directory-with-a-long-path) +* [Git-for-Windows' "snapshots"](https://github.com/git-for-windows/git/wiki/Git-for-Windows'-%22snapshots%22) * [Good commits](https://github.com/git-for-windows/git/wiki/Good-commits) * [How to participate](https://github.com/git-for-windows/git/wiki/How-to-participate) * [Install inside MSYS2 proper](https://github.com/git-for-windows/git/wiki/Install-inside-MSYS2-proper) From 75c503009d1579984dc82cb487948f259f3923dd Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Mon, 19 Oct 2020 16:05:56 +0100 Subject: [PATCH 449/591] added Technical-overview --- 0.-Index.md | 1 + 1 file changed, 1 insertion(+) diff --git a/0.-Index.md b/0.-Index.md index 25cb40fd2229a1..05f17b4a95e400 100644 --- a/0.-Index.md +++ b/0.-Index.md @@ -38,6 +38,7 @@ This is for the poor souls in corporate IE environments who can't expand the pag * [Silent or Unattended Installation](https://github.com/git-for-windows/git/wiki/Silent-or-Unattended-Installation) * [Sourcetrail code viewer and linkage to Visual Studio, for Git](https://github.com/git-for-windows/git/wiki/Sourcetrail-code-viewer-and-linkage-to-Visual-Studio,-for-Git) * [Symbolic Links](https://github.com/git-for-windows/git/wiki/Symbolic-Links) +* [Technical overview](https://github.com/git-for-windows/git/wiki/Technical-overview) * [The difference between MINGW and MSYS2](https://github.com/git-for-windows/git/wiki/The-difference-between-MINGW-and-MSYS2) * [Updating your SDK](https://github.com/git-for-windows/git/wiki/Updating-your-SDK) * [Using sshd to host a git server](https://github.com/git-for-windows/git/wiki/Using-sshd-to-host-a-git-server) From de84069bcb0c3197caa665908e826f56b9cd09f3 Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Mon, 19 Oct 2020 16:07:07 +0100 Subject: [PATCH 450/591] added The "Git-wrapper" --- 0.-Index.md | 1 + 1 file changed, 1 insertion(+) diff --git a/0.-Index.md b/0.-Index.md index 05f17b4a95e400..d7183823ae48f7 100644 --- a/0.-Index.md +++ b/0.-Index.md @@ -39,6 +39,7 @@ This is for the poor souls in corporate IE environments who can't expand the pag * [Sourcetrail code viewer and linkage to Visual Studio, for Git](https://github.com/git-for-windows/git/wiki/Sourcetrail-code-viewer-and-linkage-to-Visual-Studio,-for-Git) * [Symbolic Links](https://github.com/git-for-windows/git/wiki/Symbolic-Links) * [Technical overview](https://github.com/git-for-windows/git/wiki/Technical-overview) +* [The "Git-wrapper"](https://github.com/git-for-windows/git/wiki/The-%22Git-wrapper%22) * [The difference between MINGW and MSYS2](https://github.com/git-for-windows/git/wiki/The-difference-between-MINGW-and-MSYS2) * [Updating your SDK](https://github.com/git-for-windows/git/wiki/Updating-your-SDK) * [Using sshd to host a git server](https://github.com/git-for-windows/git/wiki/Using-sshd-to-host-a-git-server) From 47b7efdaf7eb15bd33f7b4e2fe1ce089cea443a7 Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Mon, 19 Oct 2020 16:09:28 +0100 Subject: [PATCH 451/591] added Upgrading the 'perl' component --- 0.-Index.md | 1 + 1 file changed, 1 insertion(+) diff --git a/0.-Index.md b/0.-Index.md index d7183823ae48f7..b25620554cf6d7 100644 --- a/0.-Index.md +++ b/0.-Index.md @@ -42,6 +42,7 @@ This is for the poor souls in corporate IE environments who can't expand the pag * [The "Git-wrapper"](https://github.com/git-for-windows/git/wiki/The-%22Git-wrapper%22) * [The difference between MINGW and MSYS2](https://github.com/git-for-windows/git/wiki/The-difference-between-MINGW-and-MSYS2) * [Updating your SDK](https://github.com/git-for-windows/git/wiki/Updating-your-SDK) +* [Upgrading the 'perl' component to a new version](https://github.com/git-for-windows/git/wiki/Upgrading-the-%60perl%60-component-to-a-new-version) * [Using sshd to host a git server](https://github.com/git-for-windows/git/wiki/Using-sshd-to-host-a-git-server) * [Vagrant](https://github.com/git-for-windows/git/wiki/Vagrant) * [Visual Studio and MSVC compilation](https://github.com/git-for-windows/git/wiki/Visual-Studio-and-MSVC-compilation) From 12b66f324572932a859186e4e40395904ceee833 Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Mon, 19 Oct 2020 16:11:53 +0100 Subject: [PATCH 452/591] removed fork(), exec(), CreateProcess(): Windows vs Linux - Now simply "exec() semantics" --- 0.-Index.md | 1 - 1 file changed, 1 deletion(-) diff --git a/0.-Index.md b/0.-Index.md index b25620554cf6d7..982eb0d7e3351c 100644 --- a/0.-Index.md +++ b/0.-Index.md @@ -15,7 +15,6 @@ This is for the poor souls in corporate IE environments who can't expand the pag * [exec() semantics](https://github.com/git-for-windows/git/wiki/exec()-semantics) * [FAQ](https://github.com/git-for-windows/git/wiki/FAQ) * [File names, Branch names, Path quotation, Executable bit and file modes, core.FileMode](https://github.com/git-for-windows/git/wiki/File-names,-Branch-names,-Path-quotation,-Executable-bit-and-file-modes,-core.FileMode) -* [fork(), exec(), CreateProcess(): Windows vs Linux](https://github.com/git-for-windows/git/wiki/Windows-vs-Linux-fork()/exec()-semantics) * [Git cannot create a file or directory with a long path](https://github.com/git-for-windows/git/wiki/Git-cannot-create-a-file-or-directory-with-a-long-path) * [Git-for-Windows' "snapshots"](https://github.com/git-for-windows/git/wiki/Git-for-Windows'-%22snapshots%22) * [Good commits](https://github.com/git-for-windows/git/wiki/Good-commits) From 714cb333e5b2ea33918f82bf9b7965389e4ef24b Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Thu, 5 Nov 2020 01:19:57 +0100 Subject: [PATCH 453/591] Mention that Git for Windows older than v2.29.2(2) is vulnerable (due to a Git LFS bug) --- FAQ.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/FAQ.md b/FAQ.md index da3c22a38ebf69..95d178326a62f3 100644 --- a/FAQ.md +++ b/FAQ.md @@ -27,7 +27,7 @@ In the meantime you could try: In general, yes: it is a good idea to stay up-to-date. -If you have a version older than 2.26.1, it is *highly* advisable to upgrade. A couple of Git versions came with important fixes to security-relevant vulnerabilities: 2.26.1, 2.24.1(2), 2.17.1(2), 2.14.1, 2.7.4, 2.7.0, 2.6.1, 2.5.2, 1.9.5-preview20150319, and 1.9.5-preview20141217. +If you have a version older than 2.26.1, it is *highly* advisable to upgrade. A couple of Git versions came with important fixes to security-relevant vulnerabilities: 2.29.2(2), 2.26.1, 2.24.1(2), 2.17.1(2), 2.14.1, 2.7.4, 2.7.0, 2.6.1, 2.5.2, 1.9.5-preview20150319, and 1.9.5-preview20141217. ## What is the release cadence of Git for Windows? From 2aa80e2c01c8620534fb3fb4295bc81b86b72e80 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Thu, 5 Nov 2020 01:30:55 +0100 Subject: [PATCH 454/591] Touch up the recent edits --- Issue-reporting-guidelines.md | 9 +++------ 1 file changed, 3 insertions(+), 6 deletions(-) diff --git a/Issue-reporting-guidelines.md b/Issue-reporting-guidelines.md index 9a51f1555784d7..acd9e1bdd3fcca 100644 --- a/Issue-reporting-guidelines.md +++ b/Issue-reporting-guidelines.md @@ -1,9 +1,6 @@ -# BEGIN HERE -*Search Existing issues & pull requests: -* [Open](https://github.com/git-for-windows/git/issues?q=is%3Aopen) and [closed](https://github.com/git-for-windows/git/issues?q=is%3Aclosed) issues. -*Determine weather or not a bug report has been dispatched. What is the status of the report? Are there any other bugs to be looked at? If so issue another bug report. -* Include the output of the ___git--version___ in addition to the Windows version as sometimes problems arise that are directly dependent on the physical hardware type of server being used. Notating the git/ Windows version is super important to resolving the issues at times. Likewise, please mention your usage of 32-bit Windows &/Or 32-bit Git on a 64-bit Windows ectara. The more info the better. It's better to over do it than leave a lot of guess work! :) -* Detail the option choice(S) used when installing Git for Windows, console type/window (if any). The goal is excellent communication. Think of it like you're trying to explain your process to a child using clear, simple, precise notes to help us understand your method and findings. Prevents ha +* Search Existing issues & pull requests, both [open](https://github.com/git-for-windows/git/issues?q=is%3Aopen) and [closed](https://github.com/git-for-windows/git/issues?q=is%3Aclosed). Determine whether or not a bug report has been dispatched. What is the status of the report? Are there any other bugs to be looked at? If so issue another bug report. +* Include the output of the `git --version` in addition to the Windows version as that information is often necessary to reproduce the issue. When reporting problems involving a server, include the same information for the server side (insofar possible). Likewise, please mention if you use 32-bit Windows, or a 32-bit version of Git on a 64-bit Windows. If in doubt, try to provide more information rather then less; It's better than leaving a lot of guess work! :) +* Describe the options used when installing Git for Windows, and the console type/window (if any). * If your setup is different from "normal" setups in any way, it is a good idea to put specifics about that into your bug report, too. * Describe your issue properly. If you spend 30 seconds throwing out a sloppy report, do expect that others will spend exactly the same amount on trying to resolve it. In contrast, if you write a complete and pleasantly informative bug report, you will almost certainly be rewarded by excellent help with your problem. * Include a [Minimal, Complete, and Verifiable example](http://stackoverflow.com/help/mcve) using GitHub Markdown's `codeblock` delimiters. From 44e374d0ea61c2e1b92b765155f291eef9b39415 Mon Sep 17 00:00:00 2001 From: Philippe Blain Date: Thu, 3 Dec 2020 10:50:24 -0500 Subject: [PATCH 455/591] Good commits: fix link to ablogaboutcode article --- Good-commits.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Good-commits.md b/Good-commits.md index 4c700476d5bae7..3254dfe04a7d16 100644 --- a/Good-commits.md +++ b/Good-commits.md @@ -39,4 +39,4 @@ Further reading on commit messages: - http://tbaggery.com/2008/04/19/a-note-about-git-commit-messages.html - http://gitforteams.com/resources/commit-granularity.html - http://chris.beams.io/posts/git-commit/ -- http://ablogaboutcode.com/2011/03/23/proper-git-commit-messages-and-an-elegant-git-history/ \ No newline at end of file +- http://ablogaboutcode.com/2011/03/23/proper-git-commit-messages-and-an-elegant-git-history \ No newline at end of file From 34747f25aff9fc6e97c539f276b1f990cc4f3e27 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Tue, 8 Dec 2020 22:23:23 +0100 Subject: [PATCH 456/591] Mention that v2.29.2(3) also is one of those versions with critical security fixes --- FAQ.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/FAQ.md b/FAQ.md index 95d178326a62f3..253cee58a2af6f 100644 --- a/FAQ.md +++ b/FAQ.md @@ -27,7 +27,7 @@ In the meantime you could try: In general, yes: it is a good idea to stay up-to-date. -If you have a version older than 2.26.1, it is *highly* advisable to upgrade. A couple of Git versions came with important fixes to security-relevant vulnerabilities: 2.29.2(2), 2.26.1, 2.24.1(2), 2.17.1(2), 2.14.1, 2.7.4, 2.7.0, 2.6.1, 2.5.2, 1.9.5-preview20150319, and 1.9.5-preview20141217. +If you have a version older than 2.26.1, it is *highly* advisable to upgrade. A couple of Git versions came with important fixes to security-relevant vulnerabilities: 2.29.2(3), 2.29.2(2), 2.26.1, 2.24.1(2), 2.17.1(2), 2.14.1, 2.7.4, 2.7.0, 2.6.1, 2.5.2, 1.9.5-preview20150319, and 1.9.5-preview20141217. ## What is the release cadence of Git for Windows? From 39625d13ac33bec543f84fb5c546eb438820c96b Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Wed, 9 Dec 2020 16:17:56 +0100 Subject: [PATCH 457/591] Describe Git for Windows' versioning scheme --- Versioning.md | 10 ++++++++++ 1 file changed, 10 insertions(+) create mode 100644 Versioning.md diff --git a/Versioning.md b/Versioning.md new file mode 100644 index 00000000000000..05315c2792179c --- /dev/null +++ b/Versioning.md @@ -0,0 +1,10 @@ +Git for Windows is a fork of Git, and therefore follows Git's versions. Therefore, whenever a new Git version comes out, we release a new Git for Windows version whose version number is derived from Git's. Example: short after [Git v2.29.0](https://github.com/git/git/blob/v2.29.2/Documentation/RelNotes/2.29.2.txt) was released, [Git for Windows v2.29.0](https://github.com/git-for-windows/git/releases/tag/v2.29.2.windows.1) was released. + +Sometimes, Git for Windows needs to release intermediate versions that do not follow a release by the Git project. For example, in November 2020 a new Git LFS version was released that fixed a critical security bug. Since Git for Windows ships with Git LFS included and enabled by default, we had to quickly release a new Git for Windows version, too. We called the corresponding tag [`v2.29.2.windows.2`](https://github.com/git-for-windows/git/releases/tag/v2.29.2.windows.2) and the version "v2.29.0(2)" (the first part of the version still indicates the upstream Git version, and the number in parentheses indicates the iteration of Git for Windows on top of that, and that number is identical to the suffix of the tag name). + +In December, Git Credential Manager Core followed with a version fixing a severe vulnerability, and since Git for Windows bundles that component and enables it by default, a new Git for Windows version was necessary, too. We call this version v2.29.0(3) with its corresponding tag [`v2.29.2.windows.3`](https://github.com/git-for-windows/git/releases/tag/v2.29.2.windows.3). + +Technically, the most important changes for such important bug fixes are not always in the [`git-for-windows/git`](https://github.com/git-for-windows/git/) repository, and therefore the tagged revisions do not _themselves_ have the fixes. However, we require those tags so that we can have proper releases up at https://github.com/git-for-windows/git/releases. + +Side note: By that naming convention, Git for Windows v2.29.0 should actually have been called v2.29.0(1), but for convenience, we simply drop the `(1)`. +There will never be a `(0)` because we will always have patches on top of upstream Git. \ No newline at end of file From 5b231f1868d55be2c8ec1d55e534b379e555633c Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Fri, 18 Dec 2020 16:19:12 +0100 Subject: [PATCH 458/591] =?UTF-8?q?Rename=20the=20``Git-for-Windows'=20"sn?= =?UTF-8?q?apshots"=C2=B4=C2=B4=20page?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit This is one of the two pages that currently prevent the repository from being checked out on Windows. Signed-off-by: Johannes Schindelin --- 0.-Index.md | 2 +- "Git-for-Windows'-\"snapshots\".md" => Snapshot-builds.md | 0 2 files changed, 1 insertion(+), 1 deletion(-) rename "Git-for-Windows'-\"snapshots\".md" => Snapshot-builds.md (100%) diff --git a/0.-Index.md b/0.-Index.md index 982eb0d7e3351c..3f816fab010569 100644 --- a/0.-Index.md +++ b/0.-Index.md @@ -16,7 +16,7 @@ This is for the poor souls in corporate IE environments who can't expand the pag * [FAQ](https://github.com/git-for-windows/git/wiki/FAQ) * [File names, Branch names, Path quotation, Executable bit and file modes, core.FileMode](https://github.com/git-for-windows/git/wiki/File-names,-Branch-names,-Path-quotation,-Executable-bit-and-file-modes,-core.FileMode) * [Git cannot create a file or directory with a long path](https://github.com/git-for-windows/git/wiki/Git-cannot-create-a-file-or-directory-with-a-long-path) -* [Git-for-Windows' "snapshots"](https://github.com/git-for-windows/git/wiki/Git-for-Windows'-%22snapshots%22) +* [Git-for-Windows' "snapshots"](https://github.com/git-for-windows/git/wiki/Snapshot-builds) * [Good commits](https://github.com/git-for-windows/git/wiki/Good-commits) * [How to participate](https://github.com/git-for-windows/git/wiki/How-to-participate) * [Install inside MSYS2 proper](https://github.com/git-for-windows/git/wiki/Install-inside-MSYS2-proper) diff --git "a/Git-for-Windows'-\"snapshots\".md" b/Snapshot-builds.md similarity index 100% rename from "Git-for-Windows'-\"snapshots\".md" rename to Snapshot-builds.md From 9faaa4cb7a9e23c954eec668dde98d71cdb052b6 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Fri, 18 Dec 2020 16:20:13 +0100 Subject: [PATCH 459/591] =?UTF-8?q?Rename=20the=20``The=20"Git-wrapper"?= =?UTF-8?q?=C2=B4=C2=B4=20page?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit This is the second of the two pages that currently prevent the repository from being checked out on Windows. Signed-off-by: Johannes Schindelin --- 0.-Index.md | 2 +- "The-\"Git-wrapper\".md" => Git-wrapper.md | 0 2 files changed, 1 insertion(+), 1 deletion(-) rename "The-\"Git-wrapper\".md" => Git-wrapper.md (100%) diff --git a/0.-Index.md b/0.-Index.md index 3f816fab010569..7a5cea13e3c921 100644 --- a/0.-Index.md +++ b/0.-Index.md @@ -38,7 +38,7 @@ This is for the poor souls in corporate IE environments who can't expand the pag * [Sourcetrail code viewer and linkage to Visual Studio, for Git](https://github.com/git-for-windows/git/wiki/Sourcetrail-code-viewer-and-linkage-to-Visual-Studio,-for-Git) * [Symbolic Links](https://github.com/git-for-windows/git/wiki/Symbolic-Links) * [Technical overview](https://github.com/git-for-windows/git/wiki/Technical-overview) -* [The "Git-wrapper"](https://github.com/git-for-windows/git/wiki/The-%22Git-wrapper%22) +* [The "Git-wrapper"](https://github.com/git-for-windows/git/wiki/Git-wrapper) * [The difference between MINGW and MSYS2](https://github.com/git-for-windows/git/wiki/The-difference-between-MINGW-and-MSYS2) * [Updating your SDK](https://github.com/git-for-windows/git/wiki/Updating-your-SDK) * [Upgrading the 'perl' component to a new version](https://github.com/git-for-windows/git/wiki/Upgrading-the-%60perl%60-component-to-a-new-version) diff --git "a/The-\"Git-wrapper\".md" b/Git-wrapper.md similarity index 100% rename from "The-\"Git-wrapper\".md" rename to Git-wrapper.md From 5714005162aa3268ca40f5aca6a4135e5107bc72 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Sat, 19 Dec 2020 14:04:43 +0100 Subject: [PATCH 460/591] Releasing Git for Windows: explain how to integrate last-minute changes outside of Git's own source code Signed-off-by: Johannes Schindelin --- Releasing-Git-for-Windows.md | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/Releasing-Git-for-Windows.md b/Releasing-Git-for-Windows.md index 53b6a22e8e6584..6e37160214a4bb 100644 --- a/Releasing-Git-for-Windows.md +++ b/Releasing-Git-for-Windows.md @@ -19,6 +19,18 @@ There are essentially three-and-a-half venues where Git for Windows bugs are rep - The Git mailing list at https://public-inbox.org/git/ - Twitter. Yep: ugh. Git for Windows is actually that popular that a couple of its users seriously think that Twitter would make for a perfectly fine way to report bugs. As if 280 characters were enough to make for a good bug report. Therefore, sometimes, when the Git for Windows maintainer feels particularly masochistic, they go to https://twitter.com/search?q=%23git-for-windows and see whether there is any valid bug report (one really has to pick out the needles between all that hay). +## In case last-minute component updates are needed + +What if, say, a new Git Credential Manager Core version needs to be snuck in at the last minute (where "last minute" is anything within the past 24h)? + +To integrate such an updated component, depending on the component type (MINGW or MSYS?) either the [`Build and publish MINGW Pacman package`](https://dev.azure.com/git-for-windows/git/_build?definitionId=32) or the [`Build and publish MSYS Pacman package` Pipeline](https://dev.azure.com/git-for-windows/git/_build?definitionId=33) need to be triggered (specifying the component name via the `package.to.build` variable at queue time). + +Once the component has been built and uploaded to Git for Windows' Pacman repositories (i.e. once that triggered Pipeline finished), the [`SyncSDKs` Pipeline](https://dev.azure.com/Git-for-Windows/git-sdk-64/_build?definitionId=9&_a=summary) must be triggered, manually. This Pipeline is responsible for installing the updated Pacman packages into the [`git-sdk-64`](https://github.com/git-for-windows/git-sdk-64) and [`git-sdk-32`](https://github.com/git-for-windows/git-sdk-64) repositories. + +Once the `git-sdk-64`/`git-sdk-32` repositories are updated, the [`git-sdk-64-extra-artifacts`](https://dev.azure.com/git-for-windows/git/_build?definitionId=29&_a=summary) and the [`git-sdk-32-extra-artifacts` Pipeline](https://dev.azure.com/git-for-windows/git/_build?definitionId=30&_a=summary) are triggered automatically, publishing certain subsets of the Git for Windows SDK as Pipeline Artifacts. The purpose of these artifacts is to accelerate the `Git Artifacts` Pipeline (see the _Kicking off the "Git Artifacts" Azure Pipeline_ section below), therefore we can only proceed with that Pipeline once both `git-sdk-64-extra-artifacts` and `git-sdk-32-extra-artifacts` runs are finished; Ironically, having to re-build the artifacts slows us down if we need to accommodate for last-minute component updates. + +It is important to wait for the Pipelines mentioned above to finish before moving on to the respective next Pipeline, otherwise the last-minute component update won't make it into the final Git artifacts. + # Rebasing Git for Windows' patches Note: this section assumes that the reader is _very_ familiar with interactive rebases, in particular with the `--rebase-merges` variant thereof. Readers without much experience in this are highly advised to read up on https://git-scm.com/docs/git-rebase#_rebasing_merges before going any further. From ca955c8fd2837496fedc31d557ec0f983be99034 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Sat, 19 Dec 2020 14:55:30 +0100 Subject: [PATCH 461/591] Fix whitespace issues Signed-off-by: Johannes Schindelin --- Auto-launching-ssh-agent-when-git-starts.md | 2 +- Building-Git.md | 2 +- Compiling-Git-with-Visual-Studio.md | 2 +- Continuous-Integration-(CI).md | 1 - Debugging-Git.md | 6 ++-- FAQ.md | 8 ++--- ...table-bit-and-file-modes,-core.FileMode.md | 8 ++--- Good-commits.md | 2 +- Install-inside-MSYS2-proper.md | 4 +-- Issue-reporting-guidelines.md | 2 +- MSYS2-Notes.md | 2 +- Making-an-installer.md | 6 ++-- ...flicts---Resolving-and-Remembering-them.md | 28 +++++++-------- Package-management.md | 2 +- Rebasing-Git-for-Windows.md | 36 +++++++++---------- Release-Hashes.md | 4 +-- Releasing-Git-for-Windows.md | 6 ++-- ...ur-Core.Editor-(e.g.-Notepad-Plus-Plus).md | 12 +++---- ...r-and-linkage-to-Visual-Studio,-for-Git.md | 12 +++---- Symbolic-Links.md | 2 +- Technical-overview.md | 6 ++-- The-difference-between-MINGW-and-MSYS2.md | 6 ++-- Updating-your-SDK.md | 4 +-- Using-sshd-to-host-a-git-server.md | 12 +++---- Vagrant.md | 2 +- Visual-Studio-and-MSVC-compilation.md | 1 - Windows-vs-Linux-fork()/exec()-semantics.md | 2 +- _Footer.md | 2 -- 28 files changed, 87 insertions(+), 95 deletions(-) diff --git a/Auto-launching-ssh-agent-when-git-starts.md b/Auto-launching-ssh-agent-when-git-starts.md index d062d5feff4aea..536dd183e147cd 100644 --- a/Auto-launching-ssh-agent-when-git-starts.md +++ b/Auto-launching-ssh-agent-when-git-starts.md @@ -1,4 +1,4 @@ -If you want your passphrase to be 'remembered' for a session (or configurable timeout period) you will need to setup an ssh-agent process to handle this key. +If you want your passphrase to be 'remembered' for a session (or configurable timeout period) you will need to setup an ssh-agent process to handle this key. Recent versions of git for windows 2.x come with an ssh agent startup script and the installer also checks if an ssh agent is currently running and asks you to kill this process. diff --git a/Building-Git.md b/Building-Git.md index 0c42b4c4377e0a..a508cf9fd204b5 100644 --- a/Building-Git.md +++ b/Building-Git.md @@ -47,7 +47,7 @@ cd /usr/src/git/t ## See also Regression Testing -Single tests, block of tests, or the whole test suite can be run, as detailed in +Single tests, block of tests, or the whole test suite can be run, as detailed in [Running Git's regression-tests](https://github.com/git-for-windows/git/wiki/Running-Git's-regression-tests) diff --git a/Compiling-Git-with-Visual-Studio.md b/Compiling-Git-with-Visual-Studio.md index dab51fdd129cc3..a029b6bdb769c4 100644 --- a/Compiling-Git-with-Visual-Studio.md +++ b/Compiling-Git-with-Visual-Studio.md @@ -6,7 +6,7 @@ Git's source code (and hence also Git for Windows' source code) is [usually buil However, as of Git for Windows v2.11.0, a much more convenient way is available: by cloning https://github.com/git-for-windows/git and checking out the `vs/main` branch, you will automatically have project definitions ready to go with Visual Studio. -Simply open the `git.sln` file and build the solution. DO NOT upgrade Build Tools to v141 - it will not work. If you are using VS 2017 or later, you need to install Build Tools v140 manually. +Simply open the `git.sln` file and build the solution. DO NOT upgrade Build Tools to v141 - it will not work. If you are using VS 2017 or later, you need to install Build Tools v140 manually. # Running the tests diff --git a/Continuous-Integration-(CI).md b/Continuous-Integration-(CI).md index 503776de4f3be7..c92a36515142ba 100644 --- a/Continuous-Integration-(CI).md +++ b/Continuous-Integration-(CI).md @@ -16,4 +16,3 @@ If you just want to update your existing SDK installation, you can do so by runn ## Git user installer builds The job that builds snapshots of the latest user is [here](https://dscho.cloudapp.net/job/gfw-msys2-build-user-installer/). Use this installer *only* if you need to verify that any bugs are fixed. Do *not* use the snapshot for production use but please wait for the [latest release](https://github.com/git-for-windows/git/releases/latest) instead. - diff --git a/Debugging-Git.md b/Debugging-Git.md index 7e57a71a3585bd..b2dc3a8a554f8d 100644 --- a/Debugging-Git.md +++ b/Debugging-Git.md @@ -95,7 +95,7 @@ $2 = 0x3236cb8 "C:/git-sdk-64/usr/src/git" ``` In some cases, the back trace is not helpful, though, most likely because the stack was somehow messed up. These issues are harder to debug, and require a lot of guess work and patience: - + 1. set a breakpoint on the main function of the command you called, e.g. `cmd_rev_parse` for `git rev-parse ...`: `b cmd_rev_parse` 2. start the debugging session: `r` 3. once execution stops in the main function, try to determine a reasonable next breakpoint by looking at the source: `l` (subsequent `l` commands will list more, `l ` will list from a given line number) @@ -134,8 +134,8 @@ Working directory e:\testrepo. Working directory e:\testrepo. (gdb) b main Breakpoint 1 at 0x4018da: file test-dump-index.c, line 57. -(gdb) r -Starting program: c:\git-sdk-64\mingw64\libexec\git-core\git-test-dump-index.exe +(gdb) r +Starting program: c:\git-sdk-64\mingw64\libexec\git-core\git-test-dump-index.exe [New Thread 13028.0x3a50] Breakpoint 1, 0x00000000004018da in main (argc=1, argv=0x6e0498) at test-dump-index.c:57 diff --git a/FAQ.md b/FAQ.md index 253cee58a2af6f..c51cda09a2ff95 100644 --- a/FAQ.md +++ b/FAQ.md @@ -84,7 +84,7 @@ Windows file paths are by default limited to 255 characters. Some repositories m All the apparent copies are simply hard links - see Issue 1997 [Use symbolic links for libexec](https://github.com/git-for-windows/git/issues/1997) for more details. ## Excel file modifications not always noticed. -Excel (and some other apps) do not update the *modified time* of its files which is used by Git to quickly detect changes. Rather Excel used the *change time* field. Git will notice the modifications if a `git status` is performed. See [issue 1000](https://github.com/git-for-windows/git/issues/1000#issuecomment-301611003) if you need more background. +Excel (and some other apps) do not update the *modified time* of its files which is used by Git to quickly detect changes. Rather Excel used the *change time* field. Git will notice the modifications if a `git status` is performed. See [issue 1000](https://github.com/git-for-windows/git/issues/1000#issuecomment-301611003) if you need more background. ## How do I access a repository hosted on a Microsoft Team Foundation Server inside a Windows domain? @@ -103,15 +103,15 @@ Some DSA keys are not considered secure anymore by OpenSSH 7. Adding "PubkeyAcce Some developers want to start git-bash (of Git for Windows SDK) with a different language. To achieve this in windows following command could be placed inside the launcher: `C:\Windows\System32\cmd.exe /c "set LANG=en_GB && start C:\git-sdk-64\git-bash.exe && exit"` -replace `en_GB` with your preferred locale. +replace `en_GB` with your preferred locale. -## I have errors while building the solution in Visual studio +## I have errors while building the solution in Visual studio (i.e. `fatal error C1083: Cannot open include file: 'openssl/ssl.h': No such file or directory`) Try to open the console and invoke `git\compat\vcbuild\vcpkg_install.bat`. Make sure that it has completed successfully, then clean and rebuild the solution. Ensure also that you are using proper Build Tools (v140). It's going by default in VS 2015. If you are using VS 2017, you need to install them manually. Do not upgrade the project to v141 - it can't be done automatically. - + ## Licenses Reproduced from [Git for Windows' release notes](https://github.com/git-for-windows/build-extra/blob/HEAD/ReleaseNotes.md#licenses): diff --git a/File-names,-Branch-names,-Path-quotation,-Executable-bit-and-file-modes,-core.FileMode.md b/File-names,-Branch-names,-Path-quotation,-Executable-bit-and-file-modes,-core.FileMode.md index 299508a3f213c0..983b371cc01809 100644 --- a/File-names,-Branch-names,-Path-quotation,-Executable-bit-and-file-modes,-core.FileMode.md +++ b/File-names,-Branch-names,-Path-quotation,-Executable-bit-and-file-modes,-core.FileMode.md @@ -1,6 +1,6 @@ # Case Preservation, Case insensitivity -Windows is case insensitive, but case preserving for filenames. Meanwhile Linux/Posix, for which Git is designed, is case sensitive. +Windows is case insensitive, but case preserving for filenames. Meanwhile Linux/Posix, for which Git is designed, is case sensitive. In addition Git branch names are stored as filenames. @@ -20,7 +20,7 @@ Many Git commands do not report errors in the way that maybe expected by Windows # Executable and Mode Bits -Linux attaches a mode word to each file, with bits that indicate if the file is executable, readable, writable, and other ownership aspects (`chmod`). This does not map well to Windows semantics, especially for the executable bit. The existing mode bits are retained in the repository tree meta data, which is then held locally in the index. +Linux attaches a mode word to each file, with bits that indicate if the file is executable, readable, writable, and other ownership aspects (`chmod`). This does not map well to Windows semantics, especially for the executable bit. The existing mode bits are retained in the repository tree meta data, which is then held locally in the index. Users may need to directly manipulate the mode bits where necessary - the [stackoverflow page](https://stackoverflow.com/a/38285462/717355) shows how to use the `--chmod` option while adding or updating files. @@ -32,7 +32,3 @@ From https://git-scm.com/docs/git-config#git-config-corefileMode > Tells Git if the executable bit of files in the working tree is to be honored. > Some filesystems lose the executable bit when a file that is marked as executable is checked out, or checks out a non-executable file with executable bit on. git-clone[1] or git-init[1] probe the filesystem to see if it handles the executable bit correctly and this variable is automatically set as necessary. - - - - diff --git a/Good-commits.md b/Good-commits.md index 3254dfe04a7d16..aa79bea46f86f4 100644 --- a/Good-commits.md +++ b/Good-commits.md @@ -24,7 +24,7 @@ A good example for a commit message is [git-for-windows/build-extra@a64fe115](gi ``` Install 7-Zip without confirmation if it is missing - + This is to allow unattended CI builds for the SFX installers. Once we have released a new net-installer for the SDK we can remove the check for 7za altogether as the SDK ships 7-Zip by default since the previous commit. diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index d1003ec52b09b4..204b862fbed787 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -12,9 +12,9 @@ Here the steps to take: 1. Open an MSYS2 terminal with `msys2_shell.cmd`. 2. Edit `/etc/pacman.conf` and just before `[mingw32]` (line #71 on my machine), add the `git-for-windows` packages repository: - + [git-for-windows] - Server = https://wingit.blob.core.windows.net/x86-64 + Server = https://wingit.blob.core.windows.net/x86-64 and optionally also the MINGW-only repository for the *opposite* architecture (i.e. MINGW32 for 64-bit SDK): diff --git a/Issue-reporting-guidelines.md b/Issue-reporting-guidelines.md index acd9e1bdd3fcca..e5bea65ae1d7be 100644 --- a/Issue-reporting-guidelines.md +++ b/Issue-reporting-guidelines.md @@ -1,4 +1,4 @@ -* Search Existing issues & pull requests, both [open](https://github.com/git-for-windows/git/issues?q=is%3Aopen) and [closed](https://github.com/git-for-windows/git/issues?q=is%3Aclosed). Determine whether or not a bug report has been dispatched. What is the status of the report? Are there any other bugs to be looked at? If so issue another bug report. +* Search Existing issues & pull requests, both [open](https://github.com/git-for-windows/git/issues?q=is%3Aopen) and [closed](https://github.com/git-for-windows/git/issues?q=is%3Aclosed). Determine whether or not a bug report has been dispatched. What is the status of the report? Are there any other bugs to be looked at? If so issue another bug report. * Include the output of the `git --version` in addition to the Windows version as that information is often necessary to reproduce the issue. When reporting problems involving a server, include the same information for the server side (insofar possible). Likewise, please mention if you use 32-bit Windows, or a 32-bit version of Git on a 64-bit Windows. If in doubt, try to provide more information rather then less; It's better than leaving a lot of guess work! :) * Describe the options used when installing Git for Windows, and the console type/window (if any). * If your setup is different from "normal" setups in any way, it is a good idea to put specifics about that into your bug report, too. diff --git a/MSYS2-Notes.md b/MSYS2-Notes.md index aa0197deef932d..e729118326ef8f 100644 --- a/MSYS2-Notes.md +++ b/MSYS2-Notes.md @@ -36,7 +36,7 @@ When trying to debug environment issues, it can be very helpful to print out the StringCbPrintf(buffer, sizeof(buffer), "env %d is '%s'\n", i, environ[i]); write(2, buffer, strlen(buffer)); } -``` +``` # Changing the colors in the Terminal diff --git a/Making-an-installer.md b/Making-an-installer.md index 6c95f202a1337e..4fc140a16544bd 100644 --- a/Making-an-installer.md +++ b/Making-an-installer.md @@ -1,18 +1,18 @@ As the installer is made by putting together files from the Git SDK, it is advisable to update those files first. To update the packages, call `pacman -Syu` ([caveats apply](https://github.com/git-for-windows/git/wiki/Package-management#updating-msys2-runtime-pacman-and-bash)). -If you want to test Git changes or make an installer from your own Git fork, you need to call +If you want to test Git changes or make an installer from your own Git fork, you need to call ```bash cd /usr/src/git make install -``` +``` for documentation changes: ```bash make install-html ``` -and *afterwards* +and *afterwards* ```bash prefix=/mingw64 make -C contrib/subtree install-html diff --git a/Merge-Conflicts---Resolving-and-Remembering-them.md b/Merge-Conflicts---Resolving-and-Remembering-them.md index f04d3dcdd08ebe..1b4b0848aaf824 100644 --- a/Merge-Conflicts---Resolving-and-Remembering-them.md +++ b/Merge-Conflicts---Resolving-and-Remembering-them.md @@ -1,6 +1,6 @@ -Work in Progress as I try and work out how to do this (06-04-2019).. +Work in Progress as I try and work out how to do this (06-04-2019).. -When building a new release for Git-for-Windows, the full range of Windows patches the maintainer applies need to be moved ([`rebase`](https://git-scm.com/docs/git-rebase)d) from being on top of the old upstream Git, to being on top of the new upstream release. +When building a new release for Git-for-Windows, the full range of Windows patches the maintainer applies need to be moved ([`rebase`](https://git-scm.com/docs/git-rebase)d) from being on top of the old upstream Git, to being on top of the new upstream release. There is a [process](https://github.com/git-for-windows/git/wiki/Rebasing-Git-for-Windows), a script and the support of the merging-rebase code, but still there maybe conflicts, old and new, especially if some of the Windows code has been adopted upstream in a different form. @@ -16,7 +16,7 @@ The documentation is terse, so let's also point to some on-line articles: * [Smarter rebase avoiding redundant work?](https://stackoverflow.com/q/10601541/717355) more rerere-train answers * [7.9 Git Tools (book) - Rerere](https://git-scm.com/book/en/v2/Git-Tools-Rerere). -So, enable `rerere` - `git config --global rerere.enabled true`, +So, enable `rerere` - `git config --global rerere.enabled true`, consider setting `git config --global rerere.autoupdate true` and away you go! Determine a previous Git-for-Windows merging-rebase end points and run the `contrib/rerere-train.sh` @@ -24,28 +24,28 @@ Determine a previous Git-for-Windows merging-rebase end points and run the `cont Remember the parameters passed to rerere-train are `` (apparently) for selecting the training set. ### From the git List -Threads about the internal workings: +Threads about the internal workings: -[saving and replaying multiple variants with rerere](https://public-inbox.org/git/1442275050-30497-1-git-send-email-gitster@pobox.com/) 2015-09-14 -[Should rerere auto-update a merge resolution?](https://public-inbox.org/git/CACPiFCJH7RSb_rz6M6ADuGi0q+oeWYhE1fNMQC0EUcCn_kCJwg@mail.gmail.com/) 2017-08-23 -[rebase: use OPT_RERERE_AUTOUPDATE()](https://public-inbox.org/git/20190319190317.6632-4-phillip.wood123@gmail.com/#r) 2019-03-19 +[saving and replaying multiple variants with rerere](https://public-inbox.org/git/1442275050-30497-1-git-send-email-gitster@pobox.com/) 2015-09-14 +[Should rerere auto-update a merge resolution?](https://public-inbox.org/git/CACPiFCJH7RSb_rz6M6ADuGi0q+oeWYhE1fNMQC0EUcCn_kCJwg@mail.gmail.com/) 2017-08-23 +[rebase: use OPT_RERERE_AUTOUPDATE()](https://public-inbox.org/git/20190319190317.6632-4-phillip.wood123@gmail.com/#r) 2019-03-19 [git/Documentation/technical/rerere.txt](https://github.com/git/git/blob/HEAD/Documentation/technical/rerere.txt) committed on 5 Aug 2018 -[git rerere unresolve file](https://public-inbox.org/git/200911211958.40872.j6t@kdbg.org/) 2009-11-21 patch series -[Make git-rerere a builtin](https://public-inbox.org/git/Pine.LNX.4.63.0612201738000.19693@wbgn013.biozentrum.uni-wuerzburg.de/) 2006-12-20 convert from a perl script -[Add a test for git-rerere](https://public-inbox.org/git/Pine.LNX.4.63.0612201737190.19693@wbgn013.biozentrum.uni-wuerzburg.de/) 2006-12-20 +[git rerere unresolve file](https://public-inbox.org/git/200911211958.40872.j6t@kdbg.org/) 2009-11-21 patch series +[Make git-rerere a builtin](https://public-inbox.org/git/Pine.LNX.4.63.0612201738000.19693@wbgn013.biozentrum.uni-wuerzburg.de/) 2006-12-20 convert from a perl script +[Add a test for git-rerere](https://public-inbox.org/git/Pine.LNX.4.63.0612201737190.19693@wbgn013.biozentrum.uni-wuerzburg.de/) 2006-12-20 ### Patch series, Rebase and Merge conflicts: When and where -For the rerere (redo) database, it is worth taking a few moments to consider the difference between the conflict resolution that you would perform during a rebase when a patch fails to merge cleanly, and the conflict resolution for a merge. +For the rerere (redo) database, it is worth taking a few moments to consider the difference between the conflict resolution that you would perform during a rebase when a patch fails to merge cleanly, and the conflict resolution for a merge. -For a subsequent rebase, of the repeating merging-rebase kind, it is easy to forget that the _patches_ being forward ported to the new base commit _already_ contain the previous resolution, so will not conflict next time, unless the upstream has changed, whereupon you have a _new_ conflict to resolve. +For a subsequent rebase, of the repeating merging-rebase kind, it is easy to forget that the _patches_ being forward ported to the new base commit _already_ contain the previous resolution, so will not conflict next time, unless the upstream has changed, whereupon you have a _new_ conflict to resolve. This partially extends to the merges _within_ the merging-rebase. If previous rebases have tidied the merging branches to avoid merge conflicts then there will be no resolutions to record. However if the cleanest approach was to resolve at merge, then the merge resolution can (should) be learned. Further, if you also had upstream changes and resolutions in the branches being merged, there may still be further residual merge resolutions to be performed. So unless the merges were clean then these are all **new** merge resolutions that should be learned (or relearned) for later reuse in redoing the next merging rebase. Moreover, if you are rebasing a series that has temporary merges from upstream or other independent side merges (?Cousins?), then these resolutions will need to be remembered for future merging-rebase is repeated (after dropping those merges from the 'todo' list) ### merging-rebase, as used in Git for Windows. - + When upstream provides a tagged release, we create a commit with duplicated content tree (same oid hash) that has parents of: the upstream release and our _previous_ release. This 'fake merge', with commit message title `Start the merging-rebase`, along with its predecessor fake merge, provides anchors for the rebase of the patch series. -A side effect is that, via the second parent line, we have many repetitions of the same patch series when searching via `blame` or `grep`, or doing a `git bisect`. The effect can be mitigated by inserting a temporary `git replace` of the `Start the merging-rebase`merge commit, by its first (upstream) parent, making the merge disappear, along with all those historical duplicate patches. It becomes: upstream Git, with Windows patches on top - simple. +A side effect is that, via the second parent line, we have many repetitions of the same patch series when searching via `blame` or `grep`, or doing a `git bisect`. The effect can be mitigated by inserting a temporary `git replace` of the `Start the merging-rebase`merge commit, by its first (upstream) parent, making the merge disappear, along with all those historical duplicate patches. It becomes: upstream Git, with Windows patches on top - simple. diff --git a/Package-management.md b/Package-management.md index 0e52ed23e16260..db06e09ab19634 100644 --- a/Package-management.md +++ b/Package-management.md @@ -73,7 +73,7 @@ To build MINGW packages, start a shell (a *MINGW* shell is recommended), clone t ```bash makepkg-mingw -s ``` - + (The `-s` flag tells `makepkg` that it should install dependencies automatically as needed.) To build MSYS packages, start a shell (the *MSYS* shell is recommended), clone the [`MSYS2-packages`](https://github.com/git-for-windows/MSYS2-packages) repository (recommended location: `/usr/src/MSYS2-packages`), `cd` to the appropriate subdirectory and call diff --git a/Rebasing-Git-for-Windows.md b/Rebasing-Git-for-Windows.md index 0a6483241b519c..3380ffb928f076 100644 --- a/Rebasing-Git-for-Windows.md +++ b/Rebasing-Git-for-Windows.md @@ -4,45 +4,45 @@ To do a *rebase* of the *Git for Windows* source onto a new [upstream](https://g 1. You want to *rebase* onto a new [upstream](https://github.com/git/git) release tagged as `v2.3.4` 2. The latest *rebase* was done onto a [upstream](https://github.com/git/git) release tagged as `v2.3.3` 3. the `origin/main` below means remote https://github.com/git-for-windows/git, its `main` branch. - You may have them named differently. + You may have them named differently. # Preconditions 1. A working [Git for Windows SDK](https://gitforwindows.org/#download-sdk). -2. A fetched build-extra repository. - `cd /usr/src/build-extra` - `git fetch` +2. A fetched build-extra repository. + `cd /usr/src/build-extra` + `git fetch` `git checkout main` (`git pull` if your branch is behind the upstream) -3. Working directory set to current *Git for Windows* source. +3. Working directory set to current *Git for Windows* source. `cd /usr/src/git` -4. Added [upstream](https://github.com/git/git) as a remote. - `git remote add git https://github.com/git/git` +4. Added [upstream](https://github.com/git/git) as a remote. + `git remote add git https://github.com/git/git` `git fetch git` # Starting the *rebase* -Run the `shears.sh` script to build up the actual *rebase* script. +Run the `shears.sh` script to build up the actual *rebase* script. `/usr/src/build-extra/shears.sh --merging --onto v2.3.4 merging-rebase` - Note: `v2.3.4` is a `tag` in the remote `git`. + Note: `v2.3.4` is a `tag` in the remote `git`. See the script if you are testing changes initiated in a local branch of the git upstream. -The *rebase* should start automatically and occasionally stop if it hits any merge conflicts. Resolve those conflicts (see also [Merge Conflicts Resolving and Remembering them](https://github.com/git-for-windows/git/wiki/Merge-Conflicts---Resolving-and-Remembering-them)) and then continue the rebase. +The *rebase* should start automatically and occasionally stop if it hits any merge conflicts. Resolve those conflicts (see also [Merge Conflicts Resolving and Remembering them](https://github.com/git-for-windows/git/wiki/Merge-Conflicts---Resolving-and-Remembering-them)) and then continue the rebase. `git rebase --continue` Note: the `merging-rebase` argument is a special placeholder that is interpreted by the `shears.sh` script to find the commit that started the previous merging-rebase. You can find the commit yourself like this: `BASE="$(git rev-parse HEAD^{/^"Start the merging-rebase"})"` # Verifying the *rebase* -1. Generate a *diff* of the previous state. +1. Generate a *diff* of the previous state. `git diff v2.3.3..origin/main > prev.diff` -2. Generate a *diff* of the current state. +2. Generate a *diff* of the current state. `git diff v2.3.4..main > curr.diff` -3. *Diff* the *diffs*. +3. *Diff* the *diffs*. `git diff --no-index prev.diff curr.diff` - >Ideally, the resulting output will show changes only in the `@@` lines of `prev.diff` vs `curr.diff`. - >It's a bit hard to read, though, because it is a diff of a diff. - >So meta. - >When there is a line that starts with a `-` or a `+` but then continues with a space, that's good! + >Ideally, the resulting output will show changes only in the `@@` lines of `prev.diff` vs `curr.diff`. + >It's a bit hard to read, though, because it is a diff of a diff. + >So meta. + >When there is a line that starts with a `-` or a `+` but then continues with a space, that's good! >It means that the context of our changes changed. In addition to that, you can also use the `range-diff` command to verify the rebase: @@ -70,6 +70,6 @@ To verify that everything worked as intended, you need to watch out for lines th The output is color-coded in two levels: the familiar green/red (as in `git diff`'s output) corresponds to added/removed lines. The second level is dim/bright: if green/red lines are dim, that indicates that this is the pre-rebase version of the patch; conversely, any bright green/red lines indicate post-rebase versions. More notes on reading the output of this `range-diff` command: -- It is quite common that the context changes, e.g. when a new `#include` line was introduced both in the rebased patch as well as upstream (in which case, the upstream line would be marked with an outer diff marker, but the line itself would be uncolored because it is in the context of the post-rebase version of the patch). +- It is quite common that the context changes, e.g. when a new `#include` line was introduced both in the rebased patch as well as upstream (in which case, the upstream line would be marked with an outer diff marker, but the line itself would be uncolored because it is in the context of the post-rebase version of the patch). - When whole commits are marked in red, they have been dropped during the rebase. This is quite normal when patches were "upstreamed". - Sometimes, commits are marked in red, as if they were removed, but there are also green lines that "re-introduce" them. That happens when `range-diff` fails to detect that the pre-rebase and post-rebase versions of the commit correspond to one another. This can be fixed by passing a `--creation-factor` to the `range-diff` command (sensible values are between 60, the default, and 100). \ No newline at end of file diff --git a/Release-Hashes.md b/Release-Hashes.md index be804a2f832b0f..d38ef2b34278c1 100644 --- a/Release-Hashes.md +++ b/Release-Hashes.md @@ -1,5 +1,5 @@ Release hashes are detailed in: * the ANNOUNCE mail notifications on the list and -* on the https://github.com/git-for-windows/git/releases page. +* on the https://github.com/git-for-windows/git/releases page. -The list can be read and joined at https://groups.google.com/forum/#!forum/git-for-windows \ No newline at end of file +The list can be read and joined at https://groups.google.com/forum/#!forum/git-for-windows diff --git a/Releasing-Git-for-Windows.md b/Releasing-Git-for-Windows.md index 6e37160214a4bb..8a1354df59386e 100644 --- a/Releasing-Git-for-Windows.md +++ b/Releasing-Git-for-Windows.md @@ -49,7 +49,7 @@ The trick is not just to run `/usr/src/build-extra/shears.sh --merging --onto ` phase, just follow the process as described above. This will publish one of those `(2)` versions, e.g. v2.24.1(2). Typically this happens _very_ close after an official release e.g. when really serious bugs crept into Git for Windows unnoticed, such as Git GUI crashing before even showing the window. -In the hypothetical case that a quick-fix release is necessary during the `-rc` phase, _after_ `main` was pushed, i.e. needing to branch off of an earlier revision of `main`, all the above steps can be performed with ease (as the Pipelines do not run directly on `main`, but instead require `use.branch` to be set). The only tricky part is pushing the result to `main`. The recommended way is to use the next merging rebase to pull in the changes by inserting another fake merge before the one inserted by `shears.sh`. \ No newline at end of file +In the hypothetical case that a quick-fix release is necessary during the `-rc` phase, _after_ `main` was pushed, i.e. needing to branch off of an earlier revision of `main`, all the above steps can be performed with ease (as the Pipelines do not run directly on `main`, but instead require `use.branch` to be set). The only tricky part is pushing the result to `main`. The recommended way is to use the next merging rebase to pull in the changes by inserting another fake merge before the one inserted by `shears.sh`. diff --git a/Setting-your-Core.Editor-(e.g.-Notepad-Plus-Plus).md b/Setting-your-Core.Editor-(e.g.-Notepad-Plus-Plus).md index 1c43e9885d0ead..d51c45651b1dc4 100644 --- a/Setting-your-Core.Editor-(e.g.-Notepad-Plus-Plus).md +++ b/Setting-your-Core.Editor-(e.g.-Notepad-Plus-Plus).md @@ -7,9 +7,9 @@ Many users prefer their local Windows graphic editor, such as Notepad++, this no Notepad++ provides multiple useful options ([Npp](http://notepad-plus-plus.org) [wiki](http://docs.notepad-plus-plus.org/)). Install as required. -The command +The command -`git config --global core.editor "'C:/Program Files/Notepad++/notepad++.exe' -multiInst -notabbar -nosession -noplugin`" +`git config --global core.editor "'C:/Program Files/Notepad++/notepad++.exe' -multiInst -notabbar -nosession -noplugin`" should set up the following within your config file. @@ -18,14 +18,14 @@ should set up the following within your config file. editor = 'C:/Program Files/Notepad++/notepad++.exe' -multiInst -notabbar -nosession -noplugin -Note that the windows executable path will probably need quoting to keep it as a single argument. You will need to adjust the path to match that of your OS version's programme files. +Note that the windows executable path will probably need quoting to keep it as a single argument. You will need to adjust the path to match that of your OS version's programme files. -The first three options make Notepad++ open a new, separate, simple window looking like a plain +The first three options make Notepad++ open a new, separate, simple window looking like a plain vanilla Windows Notepad screen for each git editor call, with the right action when that window is closed. -Some users prefer not to use the '-notabbar', as it may become a preferred option if you didn't +Some users prefer not to use the '-notabbar', as it may become a preferred option if you didn't have an Npp session already open, though the -nosession should prevent this. -The canonical discussion is at [stackoverflow/1634161](http://stackoverflow.com/questions/1634161/how-do-i-use-notepad-or-other-with-msysgit). Note that in Git for Windows, with its MSYS2 underpinnings, we do pass paths that are +The canonical discussion is at [stackoverflow/1634161](http://stackoverflow.com/questions/1634161/how-do-i-use-notepad-or-other-with-msysgit). Note that in Git for Windows, with its MSYS2 underpinnings, we do pass paths that are understandable by Npp, so there should be no need for any of the Cygwin path mangling trickery discussed in the SO thread. diff --git a/Sourcetrail-code-viewer-and-linkage-to-Visual-Studio,-for-Git.md b/Sourcetrail-code-viewer-and-linkage-to-Visual-Studio,-for-Git.md index fd365ebf13c215..335f53561db9d7 100644 --- a/Sourcetrail-code-viewer-and-linkage-to-Visual-Studio,-for-Git.md +++ b/Sourcetrail-code-viewer-and-linkage-to-Visual-Studio,-for-Git.md @@ -1,6 +1,6 @@ [Sourcetrail](https://www.sourcetrail.com) is an interactive source explorer that simplifies navigation in existing source code. It is [now open source](https://www.sourcetrail.com/blog/open_source/). You can support them on Patreon. -This note is a quick start to setting up a Sourcetrail project for exploring the Git source code in conjunction with Visual Studio. Source trail is configurable and some parameter need to be set on initial project setup. +This note is a quick start to setting up a Sourcetrail project for exploring the Git source code in conjunction with Visual Studio. Source trail is configurable and some parameter need to be set on initial project setup. 1. Git-for-Windows is available as a Visual Studio .sln in the `vs/main` [branch](https://github.com/git-for-windows/git/tree/vs/main) . It comprises ~19 sub-projects including `git` and `libgit`. 2. This was tested with the free VS2017 community edition. @@ -10,7 +10,7 @@ This note is a quick start to setting up a Sourcetrail project for exploring the For Git, Sourcetrail will need it's pre-processor dependencies which are numerous, so let's extract them from Visual Studio. We need to collect the main preprocessor directives from `libgit` (which everything depends on) and `git`. -1. Browse the VS project properties. Find the `C/C++` tab list, open, find 'Preprocessor', then (see top of list) "Preprocessor Definitions" with a long list of ";" separated values. Copy them for both `git` and `libgit` into your favourite editor. +1. Browse the VS project properties. Find the `C/C++` tab list, open, find 'Preprocessor', then (see top of list) "Preprocessor Definitions" with a long list of ";" separated values. Copy them for both `git` and `libgit` into your favourite editor. 2. Change ";" to "\n-D " (i.e. newline then -D ), with a `-D ` for the first value from each original line as well, etc. 3. Remove the "-D %(additional..)" lines. 4. Add `-std=c99` and `-nologo` options to the end of the option list, which now should be one per line. @@ -24,12 +24,12 @@ Now let's create the Sourcetrail project 4. "Headers & directories to index": click 'select from Compilation database', then tick './' only (leave all the 'Windows Kits' unchecked). scroll down, "exluded's" left blank; Next. (flicks back to the New Project dialog, but as it is still selecting the source groups (C/C++ from Compilation Database) its looks unchanged), - -5. scroll down, "Additional Compile Flags" selecting the scribble pen icon, paste in the "Preprocessor Definitions" (one per line) prepared above. + +5. scroll down, "Additional Compile Flags" selecting the scribble pen icon, paste in the "Preprocessor Definitions" (one per line) prepared above. 6. select "General" in top left side, and update the project name to (e.g.) "Git_sourcetrail". Location is usually ok e.g."C:/git-sdk-64/usr/src/git". "Create" ! (or maybe Next) -* switch back to the other Sourcetrail window (now active, with a fresh blue 'start Indexing' dialog). "All files" (dot in circle) should already be selected. -* Click 'Start', wait ~one minute (00:01:38). +* switch back to the other Sourcetrail window (now active, with a fresh blue 'start Indexing' dialog). "All files" (dot in circle) should already be selected. +* Click 'Start', wait ~one minute (00:01:38). Should work. \ No newline at end of file diff --git a/Symbolic-Links.md b/Symbolic-Links.md index d748e8d5a9f95d..ecbc41280f6ac0 100644 --- a/Symbolic-Links.md +++ b/Symbolic-Links.md @@ -30,7 +30,7 @@ mklink this-link-points-to c:\that-file # Allowing non-administrators to create symbolic links -The privilege of `Create symbolic links` can be assigned using local policy editors (or via policies from Active Directory in case of domain accounts). Home Editions of Windows do not have these policy editors, but the freely available [Polsedit](http://www.southsoftware.com) can be used on these editions. +The privilege of `Create symbolic links` can be assigned using local policy editors (or via policies from Active Directory in case of domain accounts). Home Editions of Windows do not have these policy editors, but the freely available [Polsedit](http://www.southsoftware.com) can be used on these editions. - Local Group Policy Editor: Launch `gpedit.msc`, navigate to `Computer Configuration - Windows Settings - Security Settings - Local Policies - User Rights Assignment` and add the account(s) to the list named `Create symbolic links`. diff --git a/Technical-overview.md b/Technical-overview.md index 835ffc1dfe798d..0c18ab87d3d3db 100644 --- a/Technical-overview.md +++ b/Technical-overview.md @@ -20,7 +20,7 @@ If you only want an installer of the latest development version of git, then you The sources of git are checked out in `/usr/src/git`. [Hack in (and test)](Building-Git) the changes you want... -Afterwards you need to install git to make these changes available to the installer build: `cd /usr/src/git && make install`. +Afterwards you need to install git to make these changes available to the installer build: `cd /usr/src/git && make install`. If you made any documentation changes, you need to install the documentation too: `make install-html && prefix=/mingw64 make -C contrib/subtree install-html` (the second make invocation installs the `git-subtree.html` which is otherwise missing and leads to an error by the portable installer). @@ -56,9 +56,9 @@ To build a portable installer, use: ``` The last line of the log shows where the installer packages were created (usually in your user directory: `c:\Users\ `). -See also: +See also: * [Debugging git](Debugging-Git) with gdb -* Running Git's [regression tests](Running-Git's-regression-tests) +* Running Git's [regression tests](Running-Git's-regression-tests) * MSYS/MINGW [package management](Package-management#technical-details) * [Updating the SDK](https://github.com/git-for-windows/git/wiki/Updating-your-SDK) * [MSYS2](https://msys2.github.io/) \ No newline at end of file diff --git a/The-difference-between-MINGW-and-MSYS2.md b/The-difference-between-MINGW-and-MSYS2.md index a2366d9e83776e..c233b872323eb8 100644 --- a/The-difference-between-MINGW-and-MSYS2.md +++ b/The-difference-between-MINGW-and-MSYS2.md @@ -31,7 +31,7 @@ It still required a two-month effort to bring everything to a state where Git's In order to support Git fully, Git for Windows needs a way to execute the shell scripts that are *still* a core part of Git. To do so, we use a stripped-down MSYS2 (which in turn is a modified version of Cygwin - [read more here](https://github.com/msys2/msys2/wiki/How-does-MSYS2-differ-from-Cygwin)). -Now, to understand the packages' names better, we need to understand how MSYS2 packages are compared to MINGW packages. +Now, to understand the packages' names better, we need to understand how MSYS2 packages are compared to MINGW packages. MSYS2's runtime is `\usr\bin\msys-2.0.dll`. It is an implicit dependency of all MSYS2 executables (most of which live in \usr\bin). This runtime provides emulation for all POSIX functionality enjoyed e.g. by Linux software. This means that it is *a lot* easier to port Linux projects to MSYS2 than it is to straight Windows. So when porting Bash or OpenSSH, it is much, much easier to port them to an MSYS2 package. @@ -39,7 +39,7 @@ So why don't we just make all packages MSYS2 ones? The POSIX emulation is *slow* So it is much preferred to port Linux software to pure Win32 calls, without going the POSIX emulation route. Of course, this is a ton more work *per project*. That is the reason why this is not done for all packages. You may want to read [this article](https://github.com/git-for-windows/git/wiki/Windows-vs-Linux-fork()/exec()-semantics) for getting an acquaintance of just a part of underlying problems. Normally, we use Visual C++ compiler on Windows. When building Windows software using GCC, it is necessary to have all the support headers and libraries. They are not provided by Microsoft, but by a separate project called MINGW ("Minimal GNU on Windows"). MSYS2 uses these MINGW libraries (and MINGW GCC compiler) to build pure Win32 packages, and those are called MINGW packages. - + That is the difference between `\usr\src\MSYS2-packages` and `\usr\src\MINGW-packages`. To discern those packages from one another, the MINGW packages all start with the prefix `mingw-w64-`. @@ -51,7 +51,7 @@ A 64-bit MSYS2 process always uses the 64-bit MSYS2 runtime, and this runtime ne So when you try to upgrade Bash in a 32-bit Git for Windows SDK (which is a slightly modified version of MSYS2, specifically crafted to support Git for Windows' development), it is clear that `pacman -Sy bash` will only upgrade a 32-bit Bash, not a 64-bit one. However, if you want to install a 32-bit *MINGW* package, you have to be able to discern that from a 64-bit MINGW package. - + For example, you could install MINGW cURL in both 32-bit and 64-bit versions. To enable that, there is a further convention that the MINGW packages have not only the prefix `mingw-w64-` but also the infix `i686-` for 32-bit, and `x86_64-` for 64-bit packages. The 32-bit MINGW cURL is offered, therefore, in the `mingw-w64-i686-curl` package, the 64-bit one in `mingw-w64-x86_64-curl`. To allow for side-by-side installation, the 32-bit MINGW files are installed into the `\mingw32` root, the 64-bit ones into `\mingw64`. Hence, the 64-bit curl.exe lives in `\mingw64\bin\curl.exe`. Git for Windows wants to be as fast as possible, so git.exe is compiled as a MINGW executable. diff --git a/Updating-your-SDK.md b/Updating-your-SDK.md index 5a6a5bd62d5c9a..7b91f5ce54602a 100644 --- a/Updating-your-SDK.md +++ b/Updating-your-SDK.md @@ -5,7 +5,7 @@ The [Git for Windows SDK release](https://github.com/git-for-windows/build-extra This was previously called the 'net installer', see below. It provides everything required to bootstrap a development environment, even if no git is available (or an unstable one is being worked on). It is also possible to manually extract the archive and then run `./setup-git-sdk.bat` in the MSYS2 terminal window. - + Alternatively, you can also clone your own copy of the 64 bit SDK with `git clone --depth=1 https://github.com/git-for-windows/git-sdk-64` (or `...-32` for 32-bit)... (select depth to taste) (See #816). The repository contains exes and DLLS so you should run the rebase script for the 32 bit version. The SDK contains core parts of MSYS2 Runtime, MinGW, 'pacman' and 'gnupg' packages, carefully selected to @@ -30,7 +30,7 @@ To keep the SDK up-to-date, periodically run pacman -Syu # If core-packages are updated by this you are promted - # to restart MSYS2 without exiting back to the shell. + # to restart MSYS2 without exiting back to the shell. # Follow these instructions and repeat: pacman -Syu diff --git a/Using-sshd-to-host-a-git-server.md b/Using-sshd-to-host-a-git-server.md index 6c7d52bf9f0b19..adfca85e74a32a 100644 --- a/Using-sshd-to-host-a-git-server.md +++ b/Using-sshd-to-host-a-git-server.md @@ -22,16 +22,16 @@ Start by attempting to ssh from your client to the server. Assuming this is the The authenticity of host 'localhost (::1)' can't be established. ECDSA key fingerprint is SHA256:lZPvG6eLvsX6dRxey0ShBlYjQubifOX6yuk3atg7jQ0. - Are you sure you want to continue connecting (yes/no)? + Are you sure you want to continue connecting (yes/no)? Type 'yes' and hit enter. At this moment `%USERPROFILE%\.ssh` directory will be created for you, if it didn't exist already. In that directory will be a `known_hosts` file identifying this server as one that you trust. You should be prompted for your password at this point. Enter it in, and you should now have a remote shell on the server (congratulations if this is your first remote shell on Windows). Now exit out of that shell to return to your local machine. In either a bash window or a cmd window, enter the `.ssh` directory found in your home directory. Type `ssh-keygen` and you will be prompted like this: Generating public/private rsa key pair. - Enter file in which to save the key (/Users/yourname/.ssh/id_rsa): - Enter passphrase (empty for no passphrase): - Enter same passphrase again: + Enter file in which to save the key (/Users/yourname/.ssh/id_rsa): + Enter passphrase (empty for no passphrase): + Enter same passphrase again: Depending on how physically secure your client machine is and your local security policies, you may choose to use an empty passphrase. The passphrase is used to gain access to your local key store, so if you use an empty passphrase anyone who has access to your client machine can impersonate you. @@ -39,9 +39,9 @@ Two files will have been generated, `id_rsa` which contains your private key, an At this time you should be able to ssh from the client to the server without entering a password (but if you chose a non-empty passphrase the client will prompt you for that). When a non-empty passphrase is used, there is also the option of running ssh-agent to keep the passphrase in-memory for you, but I'll not cover that here. -If you configure multiple client machines for you can copy your `.ssh` directory from client to client, and thus you would only need one public key in `~/.ssh/authorized_keys` on the server (this is discouraged though). In any case, make sure you protect the contents of `.ssh` directory on each client. +If you configure multiple client machines for you can copy your `.ssh` directory from client to client, and thus you would only need one public key in `~/.ssh/authorized_keys` on the server (this is discouraged though). In any case, make sure you protect the contents of `.ssh` directory on each client. -### Adding projects +### Adding projects I create projects directly on the server in `%GIT_HOME%` with: `git init --bare yourproject.git` diff --git a/Vagrant.md b/Vagrant.md index 29df28dc6fafad..73f6680af6e6f5 100644 --- a/Vagrant.md +++ b/Vagrant.md @@ -14,7 +14,7 @@ Note that the prompt shows that the current directory in the ssh session inside the virtual machine is `/vagrant/` and that the files in that directory are suspiciously identical to the `/usr/src/git/` directory in your Git SDK installation. This is not by accident. In fact, the `/vagrant/` directory inside the virtual machine *is* the `/usr/src/git` directory of the hosting Git SDK. Note: This implies that the file names are case-insensitive, still, even if running inside a Linux VM. -To compile and install Git, you will have to run `make clean` first because *Git* will have built *Windows* binaries in the same directory (when we will need *Linux* binaries inside the virtual machine started by Vagrant). After calling `make install` and `export PATH=$HOME/bin:$PATH` you will be able to run the Git version built from the source files in `/vagrant/git/`. +To compile and install Git, you will have to run `make clean` first because *Git* will have built *Windows* binaries in the same directory (when we will need *Linux* binaries inside the virtual machine started by Vagrant). After calling `make install` and `export PATH=$HOME/bin:$PATH` you will be able to run the Git version built from the source files in `/vagrant/git/`. # Alternative to the Git SDK way diff --git a/Visual-Studio-and-MSVC-compilation.md b/Visual-Studio-and-MSVC-compilation.md index 12129881021785..856dc8a69c2215 100644 --- a/Visual-Studio-and-MSVC-compilation.md +++ b/Visual-Studio-and-MSVC-compilation.md @@ -33,4 +33,3 @@ part of the (typically needed) operating stack for getting *nix / POSIX code wor ### MinGW part of the (typically needed) operating stack for getting *nix / POSIX code working. see [The-difference-between-MINGW-and-MSYS2](https://github.com/git-for-windows/git/wiki/The-difference-between-MINGW-and-MSYS2) - diff --git a/Windows-vs-Linux-fork()/exec()-semantics.md b/Windows-vs-Linux-fork()/exec()-semantics.md index 4a2d5ff294c217..e14449719ca007 100644 --- a/Windows-vs-Linux-fork()/exec()-semantics.md +++ b/Windows-vs-Linux-fork()/exec()-semantics.md @@ -6,7 +6,7 @@ Note that there's a newer, single call method on Linux ([`posix_spawn()`](http:/ ## Before start -All information about Linux is a brief retelling of Robert Love's book: [Linux Kernel Development](https://doc.lagout.org/operating%20system%20/linux/Linux%20Kernel%20Development%2C%203rd%20Edition.pdf). +All information about Linux is a brief retelling of Robert Love's book: [Linux Kernel Development](https://doc.lagout.org/operating%20system%20/linux/Linux%20Kernel%20Development%2C%203rd%20Edition.pdf). I definitely recommend you to read this book by yourself, especially if this article wasn't enough for you. I will oversimplify, otherwise I'd need to put the whole book here. `fork()` on Windows is emulated by *MSYS*, while there is no `fork()` in *MINGW*. That is partially what makes [MSYS much slower than MINGW](https://github.com/git-for-windows/git/wiki/The-difference-between-MINGW-and-MSYS2). diff --git a/_Footer.md b/_Footer.md index b923b0d25dbcc6..472997268e045b 100644 --- a/_Footer.md +++ b/_Footer.md @@ -1,3 +1 @@ This is the _Git for Windows_ wiki. See [how-to-participate](https://gitforwindows.org/governance-model.html). - - From 4c6aa47622189a1d783dc73f7a25c12a92ae7cff Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Sat, 19 Dec 2020 14:59:23 +0100 Subject: [PATCH 462/591] Releasing Git for Windows: fix scriptlet It is quite possible that there are no upstreamed commits between two upstream Git tags, e.g. between -rc versions. For those, the indicated scriptlet would generate an empty `sed` script. Let's handle that case appropriately. Signed-off-by: Johannes Schindelin --- Releasing-Git-for-Windows.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Releasing-Git-for-Windows.md b/Releasing-Git-for-Windows.md index 8a1354df59386e..89d87cfc06a6a3 100644 --- a/Releasing-Git-for-Windows.md +++ b/Releasing-Git-for-Windows.md @@ -73,7 +73,7 @@ $ git gfw-range-diff origin/main HEAD | sed -e 's/^[ 0-9]*: [0-9a-f]* [=!]/ &/' \ -e 's/^[ 0-9]*: [0-9a-f]* /+&/' | - eval sed $x | + eval sed ${x:-\'\'} | clip.exe ``` From c4cf775cf9584d81ce70d1d3c89879feb4d5dbbf Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Sat, 19 Dec 2020 15:21:48 +0100 Subject: [PATCH 463/591] Releasing Git for Windows: describe a convenient alias Let's automate All The Things! Signed-off-by: Johannes Schindelin --- Releasing-Git-for-Windows.md | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/Releasing-Git-for-Windows.md b/Releasing-Git-for-Windows.md index 89d87cfc06a6a3..91c541990a1311 100644 --- a/Releasing-Git-for-Windows.md +++ b/Releasing-Git-for-Windows.md @@ -77,6 +77,13 @@ $ git gfw-range-diff origin/main HEAD | clip.exe ``` +For convenience, this can be automated via this alias: + +```ini +[alias] + pre-release-pr-range-diff = "!set -x && x=\"$(git range-diff -s origin/main^{/^Start.the}..origin/main origin/main^{/^Start.the}^..HEAD^{/^Start.the}^ | sed -n 's/^[ 0-9]*: \\([0-9a-f][0-9a-f]*\\) [=!] [ 0-9]*: \\([0-9a-f][0-9a-f]*\\).*/-e \"s\\/\\1\\/\\1 (upstream: \\2)\\/\"/p')\" && git gfw-range-diff origin/main HEAD | sed -e 's/^[ 0-9]*: [0-9a-f]* [=!]/ &/' -e 's/^[ 0-9]*: [0-9a-f]* /+&/' | eval sed ${x:-\\'\\'} | clip.exe" +``` + # Kicking off the "Git Artifacts" Azure Pipeline Direct your browser to https://dev.azure.com/git-for-windows/git/_build?definitionId=34&_a=summary and queue a new build ("Run pipeline") with the build variable `use.branch` set to something like `rebase-to-v2.27.0@https://github.com/dscho/git` and `Branch/tag` set to the PR's tip commit (e.g. `refs/pull/2645/head`). From e650d704852a17d2bbc62cf13b082e69e9cd5391 Mon Sep 17 00:00:00 2001 From: Dan Moseley Date: Sun, 27 Dec 2020 13:48:11 -0800 Subject: [PATCH 464/591] How to recover from empty clone --- Building-Git.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Building-Git.md b/Building-Git.md index a508cf9fd204b5..44c7874a742657 100644 --- a/Building-Git.md +++ b/Building-Git.md @@ -10,7 +10,7 @@ We build Git for Windows using an [MSYS2](https://msys2.github.io/) based *Git f 2. Open the *Git for Windows SDK* *MinGW* shell by double clicking either the Shortcut on the desktop `Git SDK 32-bit.lnk` or by double clicking `mingw32_shell.bat` in the install folder. That is `Git SDK 64-bit.lnk` and `mingw64_shell.bat` for the `64bit` [SDK installer](https://gitforwindows.org/#download-sdk). -2. Change directory to the initial clone: `cd /usr/src/git`. +2. Change directory to the initial clone: `cd /usr/src/git`. If the directory is empty you may have the `master` branch checked out: `git checkout main`. 4. (Optional) build Git: `make install` From 83ae4ef89767b09bbbeda920804fddc4ea5df67e Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Thu, 14 Jan 2021 12:32:29 +0100 Subject: [PATCH 465/591] Mention that 2.30.0(2) fixes a vulnerability --- FAQ.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/FAQ.md b/FAQ.md index c51cda09a2ff95..6ccccce84a2513 100644 --- a/FAQ.md +++ b/FAQ.md @@ -27,7 +27,7 @@ In the meantime you could try: In general, yes: it is a good idea to stay up-to-date. -If you have a version older than 2.26.1, it is *highly* advisable to upgrade. A couple of Git versions came with important fixes to security-relevant vulnerabilities: 2.29.2(3), 2.29.2(2), 2.26.1, 2.24.1(2), 2.17.1(2), 2.14.1, 2.7.4, 2.7.0, 2.6.1, 2.5.2, 1.9.5-preview20150319, and 1.9.5-preview20141217. +If you have a version older than 2.30.0(2), it is *highly* advisable to upgrade. A couple of Git versions came with important fixes to security-relevant vulnerabilities: 2.30.0(2), 2.29.2(3), 2.29.2(2), 2.26.1, 2.24.1(2), 2.17.1(2), 2.14.1, 2.7.4, 2.7.0, 2.6.1, 2.5.2, 1.9.5-preview20150319, and 1.9.5-preview20141217. ## What is the release cadence of Git for Windows? From 6f34d184c5bd528dfe41381031fafa6482dfbd7a Mon Sep 17 00:00:00 2001 From: VUTHANHTUNG512 <61939628+VUTHANHTUNG512@users.noreply.github.com> Date: Tue, 19 Jan 2021 23:04:56 +0700 Subject: [PATCH 466/591] 192.168.1.2 --- https:--www.example.com.rest | 1 + 1 file changed, 1 insertion(+) create mode 100644 https:--www.example.com.rest diff --git a/https:--www.example.com.rest b/https:--www.example.com.rest new file mode 100644 index 00000000000000..2cc2ad29cb8750 --- /dev/null +++ b/https:--www.example.com.rest @@ -0,0 +1 @@ +154704070010726//call**4987686908302347//0899349366//0763282813//0899792190//0931288022//0909282813= \ No newline at end of file From 3bdc09f40fb4cf08fe7a109f4129af0b1587dedd Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Matthias=20A=C3=9Fhauer?= Date: Thu, 28 Jan 2021 08:28:10 +0100 Subject: [PATCH 467/591] Destroyed https: www.example.com (rest) --- https:--www.example.com.rest | 1 - 1 file changed, 1 deletion(-) delete mode 100644 https:--www.example.com.rest diff --git a/https:--www.example.com.rest b/https:--www.example.com.rest deleted file mode 100644 index 2cc2ad29cb8750..00000000000000 --- a/https:--www.example.com.rest +++ /dev/null @@ -1 +0,0 @@ -154704070010726//call**4987686908302347//0899349366//0763282813//0899792190//0931288022//0909282813= \ No newline at end of file From 47e94b91ec800d4120b48f95f6308541d6f15a60 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Thu, 25 Feb 2021 13:40:14 +0100 Subject: [PATCH 468/591] Warn less strongly against using symlinks --- Symbolic-Links.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Symbolic-Links.md b/Symbolic-Links.md index ecbc41280f6ac0..c5bf073b26975d 100644 --- a/Symbolic-Links.md +++ b/Symbolic-Links.md @@ -1,4 +1,4 @@ -Short version: there is no exact equivalent for POSIX symlinks on Windows, and the closest thing is unavailable for non-admins by default. Therefore, symlink emulation support is switched off by default and needs to be configured by you, the user, via the `core.symlinks=true` config setting. +Short version: there is no exact equivalent for POSIX symlinks on Windows, and the closest thing is unavailable for non-admins by default unless Developer Mode is enabled and a relatively recent Windows 10 version is used. Therefore, symlink emulation support is only turned on by default when that scenario is detected. Support can be enabled by the user, via the `core.symlinks=true` config setting. # Background From eae7324b0ff2a912539a0f792ec583dfcd6b2e23 Mon Sep 17 00:00:00 2001 From: Niko Ugarov Date: Wed, 3 Mar 2021 14:32:44 +0100 Subject: [PATCH 469/591] in #7: git-extra doesn't seem to exist, probably git-extras was intended --- Install-inside-MSYS2-proper.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index 204b862fbed787..fb36f1eef24ab0 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -45,7 +45,7 @@ Here the steps to take: 7. And finally install the Git/cURL packages: - pacman -S mingw-w64-x86_64-{git,git-doc-html,git-doc-man,curl} git-extra + pacman -S mingw-w64-x86_64-{git,git-doc-html,git-doc-man,curl} git-extras 8. Close the current shell and open a MINGW64 shell (`msys2_shell.cmd -mingw64`). From 0b80677bc4843db150d770ffc516d1a66fded168 Mon Sep 17 00:00:00 2001 From: Niko Ugarov Date: Wed, 3 Mar 2021 14:39:53 +0100 Subject: [PATCH 470/591] reverting previous edit, was based on wrong assumption. sorry.. --- Install-inside-MSYS2-proper.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index fb36f1eef24ab0..204b862fbed787 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -45,7 +45,7 @@ Here the steps to take: 7. And finally install the Git/cURL packages: - pacman -S mingw-w64-x86_64-{git,git-doc-html,git-doc-man,curl} git-extras + pacman -S mingw-w64-x86_64-{git,git-doc-html,git-doc-man,curl} git-extra 8. Close the current shell and open a MINGW64 shell (`msys2_shell.cmd -mingw64`). From b1b4bc32033066b60e09534fac1dd032388ac935 Mon Sep 17 00:00:00 2001 From: Dennis Ameling Date: Sat, 6 Mar 2021 15:54:30 +0100 Subject: [PATCH 471/591] Emacs Windows path should have forward slashes --- Debugging-Git.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Debugging-Git.md b/Debugging-Git.md index b2dc3a8a554f8d..2ba2d3980017ca 100644 --- a/Debugging-Git.md +++ b/Debugging-Git.md @@ -116,7 +116,7 @@ $ emacs Then type: `ESC-x gdb RETURN` -It should then prompt you to enter the name of an executable. Give it the full path to the actual executable (such as `C:\git-sdk-64\mingw64\libexec\git-core\git-test-dump-index.exe` or just `git.exe` if you want to debug a builtin). +It should then prompt you to enter the name of an executable. Give it the full path to the actual executable (such as `C:/git-sdk-64/mingw64/libexec/git-core/git-test-dump-index.exe` or just `git.exe` if you want to debug a builtin). You should get the usual gdb startup banner. At the first prompt, type `pwd`. For some reason it starts up in the exe's directory rather than the CWD of the shell. So you can cd to the root of the repo you want to work with. From a06adc4edc6cd99a309a398454c82a4f1a66d5fe Mon Sep 17 00:00:00 2001 From: Coreec <79744330+Jokerok50@users.noreply.github.com> Date: Mon, 8 Mar 2021 05:03:35 +0300 Subject: [PATCH 472/591] Updated FAQ (markdown) From 47ee4596218faa2bf3442c9031fc312d7aa6fda2 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Wed, 10 Mar 2021 09:58:57 +0100 Subject: [PATCH 473/591] v2.30.2 fixes CVE-2021-21300 --- FAQ.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/FAQ.md b/FAQ.md index 6ccccce84a2513..50295883bf122a 100644 --- a/FAQ.md +++ b/FAQ.md @@ -27,7 +27,7 @@ In the meantime you could try: In general, yes: it is a good idea to stay up-to-date. -If you have a version older than 2.30.0(2), it is *highly* advisable to upgrade. A couple of Git versions came with important fixes to security-relevant vulnerabilities: 2.30.0(2), 2.29.2(3), 2.29.2(2), 2.26.1, 2.24.1(2), 2.17.1(2), 2.14.1, 2.7.4, 2.7.0, 2.6.1, 2.5.2, 1.9.5-preview20150319, and 1.9.5-preview20141217. +If you have a version older than 2.30.2, it is *highly* advisable to upgrade. A couple of Git versions came with important fixes to security-relevant vulnerabilities: 2.30.2, 2.30.0(2), 2.29.2(3), 2.29.2(2), 2.26.1, 2.24.1(2), 2.17.1(2), 2.14.1, 2.7.4, 2.7.0, 2.6.1, 2.5.2, 1.9.5-preview20150319, and 1.9.5-preview20141217. ## What is the release cadence of Git for Windows? From 8a00e89aa9b5a93ea29ca2efc7809aa1d84d8ddf Mon Sep 17 00:00:00 2001 From: joblo2021 <80086004+joblo2021@users.noreply.github.com> Date: Wed, 17 Mar 2021 18:56:56 -0400 Subject: [PATCH 474/591] Updated Symbolic Links (markdown) From ac40418fb9220ca1ef4d1d4d31adb7b24d673fcf Mon Sep 17 00:00:00 2001 From: Bishop Clark Date: Sat, 20 Mar 2021 01:20:50 -0700 Subject: [PATCH 475/591] 'mail', like 'stuff' and 'traffic', doesn't get an 's' like countable nouns do --- FAQ.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/FAQ.md b/FAQ.md index 50295883bf122a..da66c1baa1fcfc 100644 --- a/FAQ.md +++ b/FAQ.md @@ -35,7 +35,7 @@ Official Git for Windows versions mainly follow Git's release cycle: every 12 we Other than that, Git for Windows follows the *newest* Git version's maintenance releases (read: after Git for Windows v2.15.0 was released, no new Git for Windows v2.14.x version would be released). Indicators for imminent maintenance releases of Git are: -- The Git maintainer sometimes talks about this in the preamble of the ["What's cooking in git.git" mails](https://public-inbox.org/git/?q=s%3A%22what%27s+cooking%22+AND+f%3Agitster%40pobox.com). +- The Git maintainer sometimes talks about this in the preamble of the ["What's cooking in git.git" mail](https://public-inbox.org/git/?q=s%3A%22what%27s+cooking%22+AND+f%3Agitster%40pobox.com). - The [`maint` in git.git](https://github.com/git/git/commits/maint) accumulates critical patches. Finally, Git for Windows is sometimes released in "out-of-band" versions, when critical fixes specific to Git for Windows necessitate it. These out-of-band versions are indicated by appending a `(2)` to the latest release (or `(3)`, `(4)`, etc). Examples for such out-of-band versions include: [Git for Windows v2.15.1(2)](https://github.com/git-for-windows/git/releases/tag/v2.15.1.windows.2) and [Git for Windows v2.16.1(4)](https://github.com/git-for-windows/git/releases/tag/v2.16.1.windows.4). From c2ece3c3e2760c40a81b5b60031c3a77a31d0981 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Thu, 8 Apr 2021 22:35:11 +0200 Subject: [PATCH 476/591] Revert "'mail', like 'stuff' and 'traffic', doesn't get an 's' like countable nouns do" The Cambridge Dictionary disagrees with the idea that the plural of "mail" should be "mail" when talking about emails: https://dictionary.cambridge.org/dictionary/english/mail#cald4-1-2 This reverts commit ac40418fb9220ca1ef4d1d4d31adb7b24d673fcf. Signed-off-by: Johannes Schindelin --- FAQ.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/FAQ.md b/FAQ.md index da66c1baa1fcfc..50295883bf122a 100644 --- a/FAQ.md +++ b/FAQ.md @@ -35,7 +35,7 @@ Official Git for Windows versions mainly follow Git's release cycle: every 12 we Other than that, Git for Windows follows the *newest* Git version's maintenance releases (read: after Git for Windows v2.15.0 was released, no new Git for Windows v2.14.x version would be released). Indicators for imminent maintenance releases of Git are: -- The Git maintainer sometimes talks about this in the preamble of the ["What's cooking in git.git" mail](https://public-inbox.org/git/?q=s%3A%22what%27s+cooking%22+AND+f%3Agitster%40pobox.com). +- The Git maintainer sometimes talks about this in the preamble of the ["What's cooking in git.git" mails](https://public-inbox.org/git/?q=s%3A%22what%27s+cooking%22+AND+f%3Agitster%40pobox.com). - The [`maint` in git.git](https://github.com/git/git/commits/maint) accumulates critical patches. Finally, Git for Windows is sometimes released in "out-of-band" versions, when critical fixes specific to Git for Windows necessitate it. These out-of-band versions are indicated by appending a `(2)` to the latest release (or `(3)`, `(4)`, etc). Examples for such out-of-band versions include: [Git for Windows v2.15.1(2)](https://github.com/git-for-windows/git/releases/tag/v2.15.1.windows.2) and [Git for Windows v2.16.1(4)](https://github.com/git-for-windows/git/releases/tag/v2.16.1.windows.4). From 1d282bf167f71d6e75ea0ce79d3afa240c630f9d Mon Sep 17 00:00:00 2001 From: DarkSnowBallz618 <80652168+DarkSnowBallz618@users.noreply.github.com> Date: Sun, 11 Apr 2021 06:32:14 -0500 Subject: [PATCH 477/591] Created _Sidebar (markdown) --- _Sidebar.md | 2 ++ 1 file changed, 2 insertions(+) create mode 100644 _Sidebar.md diff --git a/_Sidebar.md b/_Sidebar.md new file mode 100644 index 00000000000000..2a8c25de29c917 --- /dev/null +++ b/_Sidebar.md @@ -0,0 +1,2 @@ +# {Merkel} +🐢 From 8edd79bd30233ff21b7b783879f540d397bc1b67 Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Thu, 22 Apr 2021 11:54:22 +0100 Subject: [PATCH 478/591] Updated introductory paragraph (1/2) to match the retirement of `vs/master` and the replacement with a `CMake` build in the `main` branch. --- ...ail-code-viewer-and-linkage-to-Visual-Studio,-for-Git.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/Sourcetrail-code-viewer-and-linkage-to-Visual-Studio,-for-Git.md b/Sourcetrail-code-viewer-and-linkage-to-Visual-Studio,-for-Git.md index 335f53561db9d7..9502c0ec413369 100644 --- a/Sourcetrail-code-viewer-and-linkage-to-Visual-Studio,-for-Git.md +++ b/Sourcetrail-code-viewer-and-linkage-to-Visual-Studio,-for-Git.md @@ -2,9 +2,9 @@ This note is a quick start to setting up a Sourcetrail project for exploring the Git source code in conjunction with Visual Studio. Source trail is configurable and some parameter need to be set on initial project setup. -1. Git-for-Windows is available as a Visual Studio .sln in the `vs/main` [branch](https://github.com/git-for-windows/git/tree/vs/main) . It comprises ~19 sub-projects including `git` and `libgit`. -2. This was tested with the free VS2017 community edition. -3. Build the solution(.sln) in Visual Studio so that it's `vcpkg` dependencies are downloaded and compiled (may take some time). +1. Git-for-Windows is available as a Visual Studio build in the `main` [branch](https://github.com/git-for-windows/git/tree/main). Visual Studio will detect the `CMakeLists.txt` file in `\contrib\buildsystems` to build the project. See that file for instructions on generating the `.sln` and `vcproj` files needed for Sourcetrail and other VS Extensions. The VS project comprises ~19 sub-projects including `ALL BUILD` and `libgit`. +2. This was tested with the free VS2019 community edition. +3. Build the project in Visual Studio so that it's `vcpkg` dependencies are downloaded and compiled (may take some time). 4. Download and install the Sourcetrail software. Check the [documentation](https://www.sourcetrail.com/documentation/), especially the [intro video](https://youtu.be/7fguPwKR_7Y). 5. Download and install the [VS Sourcetrail Extension](https://marketplace.visualstudio.com/items?itemName=vs-publisher-1208751.SourcetrailExtension). From 0cb55c7bb422c0c42b8e966fb85ae8ad85232986 Mon Sep 17 00:00:00 2001 From: cc520743 <82349698+cc520743@users.noreply.github.com> Date: Fri, 23 Apr 2021 14:14:32 +0800 Subject: [PATCH 479/591] Destroyed FAQ (markdown) --- FAQ.md | 123 --------------------------------------------------------- 1 file changed, 123 deletions(-) delete mode 100644 FAQ.md diff --git a/FAQ.md b/FAQ.md deleted file mode 100644 index 50295883bf122a..00000000000000 --- a/FAQ.md +++ /dev/null @@ -1,123 +0,0 @@ -## Which versions of Windows are supported? - -Git for Windows currently works with all recent, commercially released x86 32 bit and 64 bit versions of Windows, starting with Windows Vista. - -*** -NOTE: Git for Windows version [2.10.0](https://github.com/git-for-windows/git/releases/tag/v2.10.0.windows.1) was the last version supporting Windows XP and Server 2003. -*** - -Windows XP and Windows Server 2003 are long past their end of life, hence support for these versions was dropped from Git for Windows 2.10.1 and later. This limitation is inherited by Git's use of MSYS2, which in turn inherited it from [Cygwin](https://cygwin.com/ml/cygwin/2015-08/msg00446.html). - -More information here: [Git for Windows' prerequisites](https://gitforwindows.org/requirements.html). - -## Is there an MSI for installation via Group Policy? - -There is currently no MSI package; there is an exe installer and a portable package. You are welcome to contribute a Pull Request that packages a new installer. - -~There is an existing Pull Request in development and looking for testers, please try out https://github.com/robmen/gitsetup/issues/1 and give feedback.~ It's closed by now. Future development is happening [here](https://github.com/git-for-windows/build-extra/tree/HEAD/msi/). - -In the meantime you could try: - - * using the portable package - * deploying the exe installer with System Center Configuration Manager - * deploying the portable package via a script - * deploying the Chocolatey package via Puppet (or something similar) - -## Should I upgrade to a newer Git for Windows version? - -In general, yes: it is a good idea to stay up-to-date. - -If you have a version older than 2.30.2, it is *highly* advisable to upgrade. A couple of Git versions came with important fixes to security-relevant vulnerabilities: 2.30.2, 2.30.0(2), 2.29.2(3), 2.29.2(2), 2.26.1, 2.24.1(2), 2.17.1(2), 2.14.1, 2.7.4, 2.7.0, 2.6.1, 2.5.2, 1.9.5-preview20150319, and 1.9.5-preview20141217. - -## What is the release cadence of Git for Windows? - -Official Git for Windows versions mainly follow Git's release cycle: every 12 weeks or so, a new major Git version is released (see details here: https://tinyurl.com/gitCal). Typically, Git for Windows will follow suit within a day. - -Other than that, Git for Windows follows the *newest* Git version's maintenance releases (read: after Git for Windows v2.15.0 was released, no new Git for Windows v2.14.x version would be released). Indicators for imminent maintenance releases of Git are: - -- The Git maintainer sometimes talks about this in the preamble of the ["What's cooking in git.git" mails](https://public-inbox.org/git/?q=s%3A%22what%27s+cooking%22+AND+f%3Agitster%40pobox.com). -- The [`maint` in git.git](https://github.com/git/git/commits/maint) accumulates critical patches. - -Finally, Git for Windows is sometimes released in "out-of-band" versions, when critical fixes specific to Git for Windows necessitate it. These out-of-band versions are indicated by appending a `(2)` to the latest release (or `(3)`, `(4)`, etc). Examples for such out-of-band versions include: [Git for Windows v2.15.1(2)](https://github.com/git-for-windows/git/releases/tag/v2.15.1.windows.2) and [Git for Windows v2.16.1(4)](https://github.com/git-for-windows/git/releases/tag/v2.16.1.windows.4). - -## What is the relationship between *Git for Windows* and *msysGit*? - -*Git for Windows* used to be developed using the development environment called "msysGit", but roughly coinciding with Git 2.1, msysGit was superseded by a new development environment: the [Git for Windows SDK](https://github.com/git-for-windows/build-extra/releases). See [here](https://github.com/git-for-windows/git/wiki/Updating-your-SDK) to get a copy. - -## How do I update *Git for Windows* upon new releases? - -This depends on how you installed *Git for Windows*. The bundle installation requires you to download and install the new version. Any customizations you made will be kept as long as you did so in the appropriate configuration folders. - -For advanced users working with the *Git for Windows* SDK `pacman` is available as a package manager. See [Package management](Package-management) - -## How do I check the release hash and release notes - -For hashes see https://github.com/git-for-windows/git/releases - -For (G4W) release notes see the [build-extra repo](https://github.com/git-for-windows/build-extra/blob/HEAD/ReleaseNotes.md), or the top level of your installation (e.g. [C:\Program Files\Git\ReleaseNotes.html](https://www.example.com/Program%20Files/Git/ReleaseNotes.html) - via manual browsing). - -For extracting 7z/zip archives see [page](https://github.com/git-for-windows/git/wiki/Zip-Archives---extracting-the-released-archives). - -## Are there 'Nightly' builds of the latest and greatest - -The Git for Windows builds are not quite that frequent, but there are Snapshot builds listed at https://wingit.blob.core.windows.net/files/index.html - -These often 'fix' (or attempt fixes) recent issues before a new formal release. Check their commit notes and links to issues to see if your problem is included. - -## Some native console programs don't work when run from Git Bash. How to fix it? - -*Git for Windows* defaults to using [mintty](https://code.google.com/p/mintty/) terminal. Compared to default Windows console host, it provides normal multi-line cut&paste, working resizing, defaults to unicode font and avoids some bugs in the default console host. However it does not present itself as console to native applications (those *not* built with MSys or Cygwin), so in these applications: - - * Non-ASCII output may be corrupted due to mismatch in character sets (MSYS2 and Cygwin use UTF-8 while Windows will fall back to the legacy DOS codepages in this case). - * Interactive and full-screen applications won't work at all. - -There are several methods for working around these problems: - - * Run programs that have problems using the [`winpty`](https://github.com/rprichard/winpty) utility. This allows you to keep using the nicer mintty terminal, but can become unwieldy if you need the workaround for many programs. - * Modify the shortcut for Git Bash to run `bash` directly without `mintty` so it uses the default console host and configure it for "Quick Edit", reasonable size and scroll-back and suitable unicode font. You'll still have to live with the other quirks of console host. - * Install and use [ConEmu](https://conemu.github.io/). - -## I get errors trying to check out files with long path names. -Windows file paths are by default limited to 255 characters. Some repositories may have committed files which contain paths longer than the limit. By default, *Git for Windows* does not support long paths, and will print errors when trying to perform any operation on a long file name. Set the configuration property `core.longpaths` to true to allow certain Git operations to properly handle these files. See [this wiki page](https://github.com/git-for-windows/git/wiki/Git-cannot-create-a-file-or-directory-with-a-long-path) for more information. - -## The installed files are duplicated and look massive - Why? -All the apparent copies are simply hard links - see Issue 1997 [Use symbolic links for libexec](https://github.com/git-for-windows/git/issues/1997) for more details. - -## Excel file modifications not always noticed. -Excel (and some other apps) do not update the *modified time* of its files which is used by Git to quickly detect changes. Rather Excel used the *change time* field. Git will notice the modifications if a `git status` is performed. See [issue 1000](https://github.com/git-for-windows/git/issues/1000#issuecomment-301611003) if you need more background. - -## How do I access a repository hosted on a Microsoft Team Foundation Server inside a Windows domain? - -The Microsoft Team Foundation Server is capable of hosting git repositories. If the server is a member of a windows domain, and your user account is in that domain, you can use domain authentication to identify yourself to the server, and can thus access git repositories without having to enter any credentials. For this to work, the server has to be configured to use domain authentication, _not_ NTLM authentication. The repository URL can be obtained from the TFS web interface, it may look like http://server.example.com:8080/tfs/TWA/TeamDev/_git/reponame. - -In order to instruct git to use domain authentication, prefix the server name with `:@`, like so: `http://:@server.example.com:8080/tfs/TWA/TeamDev/_git/reponame`. This is a special case of the usual `username:password@server` syntax, where both the `username` and `password` fields are empty. This causes git to look up and use your domain credentials. - -See also: [Clone an existing Git repo - Azure Repos](https://docs.microsoft.com/en-us/azure/devops/repos/git/clone) - -## I get "Permission denied (publickey)." when using git pull - -Some DSA keys are not considered secure anymore by OpenSSH 7. Adding "PubkeyAcceptedKeyTypes ssh-dss" to ~/.ssh/config helps. - -## Switch locale for git-bash launcher (of Git for Windows SDK) - -Some developers want to start git-bash (of Git for Windows SDK) with a different language. -To achieve this in windows following command could be placed inside the launcher: -`C:\Windows\System32\cmd.exe /c "set LANG=en_GB && start C:\git-sdk-64\git-bash.exe && exit"` -replace `en_GB` with your preferred locale. - -## I have errors while building the solution in Visual studio -(i.e. `fatal error C1083: Cannot open include file: 'openssl/ssl.h': No such file or directory`) - -Try to open the console and invoke `git\compat\vcbuild\vcpkg_install.bat`. Make sure that it has completed successfully, then clean and rebuild the solution. - -Ensure also that you are using proper Build Tools (v140). It's going by default in VS 2015. If you are using VS 2017, you need to install them manually. Do not upgrade the project to v141 - it can't be done automatically. - -## Licenses - -Reproduced from [Git for Windows' release notes](https://github.com/git-for-windows/build-extra/blob/HEAD/ReleaseNotes.md#licenses): - -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. - -Git for Windows also contains Embedded CAcert Root Certificates. For more information please go to https://www.cacert.org/policy/RootDistributionLicense.php. - -This package contains software from a number of other projects including Bash, zlib, curl, tcl/tk, perl, MSYS2 and a number of libraries and utilities from the GNU project, licensed under the GNU General Public License. Likewise, it contains Perl which is dual licensed under the GNU General Public License and the Artistic License. From 26d9ae6d0cbf8396aac47405b8ab634a88f092f7 Mon Sep 17 00:00:00 2001 From: xbu1973 <82109938+xbu1973@users.noreply.github.com> Date: Thu, 29 Apr 2021 14:44:29 +0200 Subject: [PATCH 480/591] Created Domande frequenti (markdown) --- Domande-frequenti.md | 1 + 1 file changed, 1 insertion(+) create mode 100644 Domande-frequenti.md diff --git a/Domande-frequenti.md b/Domande-frequenti.md new file mode 100644 index 00000000000000..f7997c2199b099 --- /dev/null +++ b/Domande-frequenti.md @@ -0,0 +1 @@ +Ciao io mi chiamo emanuele. \ No newline at end of file From 331562df8e6090aa31b745933a10ce0b56f1909e Mon Sep 17 00:00:00 2001 From: xbu1973 <82109938+xbu1973@users.noreply.github.com> Date: Thu, 29 Apr 2021 14:46:35 +0200 Subject: [PATCH 481/591] Destroyed Domande frequenti (markdown) --- Domande-frequenti.md | 1 - 1 file changed, 1 deletion(-) delete mode 100644 Domande-frequenti.md diff --git a/Domande-frequenti.md b/Domande-frequenti.md deleted file mode 100644 index f7997c2199b099..00000000000000 --- a/Domande-frequenti.md +++ /dev/null @@ -1 +0,0 @@ -Ciao io mi chiamo emanuele. \ No newline at end of file From c479b231ba7cbe0dfeaaf0c38ab4cec5c0da3db7 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Matthias=20A=C3=9Fhauer?= Date: Fri, 30 Apr 2021 10:02:31 +0200 Subject: [PATCH 482/591] Destroyed _Sidebar (markdown) --- _Sidebar.md | 2 -- 1 file changed, 2 deletions(-) delete mode 100644 _Sidebar.md diff --git a/_Sidebar.md b/_Sidebar.md deleted file mode 100644 index 2a8c25de29c917..00000000000000 --- a/_Sidebar.md +++ /dev/null @@ -1,2 +0,0 @@ -# {Merkel} -🐢 From ef07d88def9ba3e95c411c5fb2db4c25abfac55e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Matthias=20A=C3=9Fhauer?= Date: Fri, 30 Apr 2021 10:05:33 +0200 Subject: [PATCH 483/591] Revert 8edd79bd30233ff21b7b783879f540d397bc1b67...0cb55c7bb422c0c42b8e966fb85ae8ad85232986 --- FAQ.md | 123 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 123 insertions(+) create mode 100644 FAQ.md diff --git a/FAQ.md b/FAQ.md new file mode 100644 index 00000000000000..50295883bf122a --- /dev/null +++ b/FAQ.md @@ -0,0 +1,123 @@ +## Which versions of Windows are supported? + +Git for Windows currently works with all recent, commercially released x86 32 bit and 64 bit versions of Windows, starting with Windows Vista. + +*** +NOTE: Git for Windows version [2.10.0](https://github.com/git-for-windows/git/releases/tag/v2.10.0.windows.1) was the last version supporting Windows XP and Server 2003. +*** + +Windows XP and Windows Server 2003 are long past their end of life, hence support for these versions was dropped from Git for Windows 2.10.1 and later. This limitation is inherited by Git's use of MSYS2, which in turn inherited it from [Cygwin](https://cygwin.com/ml/cygwin/2015-08/msg00446.html). + +More information here: [Git for Windows' prerequisites](https://gitforwindows.org/requirements.html). + +## Is there an MSI for installation via Group Policy? + +There is currently no MSI package; there is an exe installer and a portable package. You are welcome to contribute a Pull Request that packages a new installer. + +~There is an existing Pull Request in development and looking for testers, please try out https://github.com/robmen/gitsetup/issues/1 and give feedback.~ It's closed by now. Future development is happening [here](https://github.com/git-for-windows/build-extra/tree/HEAD/msi/). + +In the meantime you could try: + + * using the portable package + * deploying the exe installer with System Center Configuration Manager + * deploying the portable package via a script + * deploying the Chocolatey package via Puppet (or something similar) + +## Should I upgrade to a newer Git for Windows version? + +In general, yes: it is a good idea to stay up-to-date. + +If you have a version older than 2.30.2, it is *highly* advisable to upgrade. A couple of Git versions came with important fixes to security-relevant vulnerabilities: 2.30.2, 2.30.0(2), 2.29.2(3), 2.29.2(2), 2.26.1, 2.24.1(2), 2.17.1(2), 2.14.1, 2.7.4, 2.7.0, 2.6.1, 2.5.2, 1.9.5-preview20150319, and 1.9.5-preview20141217. + +## What is the release cadence of Git for Windows? + +Official Git for Windows versions mainly follow Git's release cycle: every 12 weeks or so, a new major Git version is released (see details here: https://tinyurl.com/gitCal). Typically, Git for Windows will follow suit within a day. + +Other than that, Git for Windows follows the *newest* Git version's maintenance releases (read: after Git for Windows v2.15.0 was released, no new Git for Windows v2.14.x version would be released). Indicators for imminent maintenance releases of Git are: + +- The Git maintainer sometimes talks about this in the preamble of the ["What's cooking in git.git" mails](https://public-inbox.org/git/?q=s%3A%22what%27s+cooking%22+AND+f%3Agitster%40pobox.com). +- The [`maint` in git.git](https://github.com/git/git/commits/maint) accumulates critical patches. + +Finally, Git for Windows is sometimes released in "out-of-band" versions, when critical fixes specific to Git for Windows necessitate it. These out-of-band versions are indicated by appending a `(2)` to the latest release (or `(3)`, `(4)`, etc). Examples for such out-of-band versions include: [Git for Windows v2.15.1(2)](https://github.com/git-for-windows/git/releases/tag/v2.15.1.windows.2) and [Git for Windows v2.16.1(4)](https://github.com/git-for-windows/git/releases/tag/v2.16.1.windows.4). + +## What is the relationship between *Git for Windows* and *msysGit*? + +*Git for Windows* used to be developed using the development environment called "msysGit", but roughly coinciding with Git 2.1, msysGit was superseded by a new development environment: the [Git for Windows SDK](https://github.com/git-for-windows/build-extra/releases). See [here](https://github.com/git-for-windows/git/wiki/Updating-your-SDK) to get a copy. + +## How do I update *Git for Windows* upon new releases? + +This depends on how you installed *Git for Windows*. The bundle installation requires you to download and install the new version. Any customizations you made will be kept as long as you did so in the appropriate configuration folders. + +For advanced users working with the *Git for Windows* SDK `pacman` is available as a package manager. See [Package management](Package-management) + +## How do I check the release hash and release notes + +For hashes see https://github.com/git-for-windows/git/releases + +For (G4W) release notes see the [build-extra repo](https://github.com/git-for-windows/build-extra/blob/HEAD/ReleaseNotes.md), or the top level of your installation (e.g. [C:\Program Files\Git\ReleaseNotes.html](https://www.example.com/Program%20Files/Git/ReleaseNotes.html) - via manual browsing). + +For extracting 7z/zip archives see [page](https://github.com/git-for-windows/git/wiki/Zip-Archives---extracting-the-released-archives). + +## Are there 'Nightly' builds of the latest and greatest + +The Git for Windows builds are not quite that frequent, but there are Snapshot builds listed at https://wingit.blob.core.windows.net/files/index.html + +These often 'fix' (or attempt fixes) recent issues before a new formal release. Check their commit notes and links to issues to see if your problem is included. + +## Some native console programs don't work when run from Git Bash. How to fix it? + +*Git for Windows* defaults to using [mintty](https://code.google.com/p/mintty/) terminal. Compared to default Windows console host, it provides normal multi-line cut&paste, working resizing, defaults to unicode font and avoids some bugs in the default console host. However it does not present itself as console to native applications (those *not* built with MSys or Cygwin), so in these applications: + + * Non-ASCII output may be corrupted due to mismatch in character sets (MSYS2 and Cygwin use UTF-8 while Windows will fall back to the legacy DOS codepages in this case). + * Interactive and full-screen applications won't work at all. + +There are several methods for working around these problems: + + * Run programs that have problems using the [`winpty`](https://github.com/rprichard/winpty) utility. This allows you to keep using the nicer mintty terminal, but can become unwieldy if you need the workaround for many programs. + * Modify the shortcut for Git Bash to run `bash` directly without `mintty` so it uses the default console host and configure it for "Quick Edit", reasonable size and scroll-back and suitable unicode font. You'll still have to live with the other quirks of console host. + * Install and use [ConEmu](https://conemu.github.io/). + +## I get errors trying to check out files with long path names. +Windows file paths are by default limited to 255 characters. Some repositories may have committed files which contain paths longer than the limit. By default, *Git for Windows* does not support long paths, and will print errors when trying to perform any operation on a long file name. Set the configuration property `core.longpaths` to true to allow certain Git operations to properly handle these files. See [this wiki page](https://github.com/git-for-windows/git/wiki/Git-cannot-create-a-file-or-directory-with-a-long-path) for more information. + +## The installed files are duplicated and look massive - Why? +All the apparent copies are simply hard links - see Issue 1997 [Use symbolic links for libexec](https://github.com/git-for-windows/git/issues/1997) for more details. + +## Excel file modifications not always noticed. +Excel (and some other apps) do not update the *modified time* of its files which is used by Git to quickly detect changes. Rather Excel used the *change time* field. Git will notice the modifications if a `git status` is performed. See [issue 1000](https://github.com/git-for-windows/git/issues/1000#issuecomment-301611003) if you need more background. + +## How do I access a repository hosted on a Microsoft Team Foundation Server inside a Windows domain? + +The Microsoft Team Foundation Server is capable of hosting git repositories. If the server is a member of a windows domain, and your user account is in that domain, you can use domain authentication to identify yourself to the server, and can thus access git repositories without having to enter any credentials. For this to work, the server has to be configured to use domain authentication, _not_ NTLM authentication. The repository URL can be obtained from the TFS web interface, it may look like http://server.example.com:8080/tfs/TWA/TeamDev/_git/reponame. + +In order to instruct git to use domain authentication, prefix the server name with `:@`, like so: `http://:@server.example.com:8080/tfs/TWA/TeamDev/_git/reponame`. This is a special case of the usual `username:password@server` syntax, where both the `username` and `password` fields are empty. This causes git to look up and use your domain credentials. + +See also: [Clone an existing Git repo - Azure Repos](https://docs.microsoft.com/en-us/azure/devops/repos/git/clone) + +## I get "Permission denied (publickey)." when using git pull + +Some DSA keys are not considered secure anymore by OpenSSH 7. Adding "PubkeyAcceptedKeyTypes ssh-dss" to ~/.ssh/config helps. + +## Switch locale for git-bash launcher (of Git for Windows SDK) + +Some developers want to start git-bash (of Git for Windows SDK) with a different language. +To achieve this in windows following command could be placed inside the launcher: +`C:\Windows\System32\cmd.exe /c "set LANG=en_GB && start C:\git-sdk-64\git-bash.exe && exit"` +replace `en_GB` with your preferred locale. + +## I have errors while building the solution in Visual studio +(i.e. `fatal error C1083: Cannot open include file: 'openssl/ssl.h': No such file or directory`) + +Try to open the console and invoke `git\compat\vcbuild\vcpkg_install.bat`. Make sure that it has completed successfully, then clean and rebuild the solution. + +Ensure also that you are using proper Build Tools (v140). It's going by default in VS 2015. If you are using VS 2017, you need to install them manually. Do not upgrade the project to v141 - it can't be done automatically. + +## Licenses + +Reproduced from [Git for Windows' release notes](https://github.com/git-for-windows/build-extra/blob/HEAD/ReleaseNotes.md#licenses): + +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. + +Git for Windows also contains Embedded CAcert Root Certificates. For more information please go to https://www.cacert.org/policy/RootDistributionLicense.php. + +This package contains software from a number of other projects including Bash, zlib, curl, tcl/tk, perl, MSYS2 and a number of libraries and utilities from the GNU project, licensed under the GNU General Public License. Likewise, it contains Perl which is dual licensed under the GNU General Public License and the Artistic License. From d909cdf53f2beefe5998a8c4e10296cab1887ce4 Mon Sep 17 00:00:00 2001 From: goonzoe76 <82881678+goonzoe76@users.noreply.github.com> Date: Fri, 30 Apr 2021 08:53:18 -0500 Subject: [PATCH 484/591] Updated _Footer (markdown) From 010c5e6c630942718c57b92ba74f28b928229819 Mon Sep 17 00:00:00 2001 From: David Macek Date: Sat, 22 May 2021 11:06:57 +0200 Subject: [PATCH 485/591] Remove explicit mingw-w64-x86_64-curl installation, it's a dependency --- Install-inside-MSYS2-proper.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index 204b862fbed787..12aba01899f641 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -37,15 +37,15 @@ Here the steps to take: 5. This updates `msys2-runtime` and therefore will ask you to close the window (*not* just exit the pacman process). Don't panic, simply close all currently open MSYS2 shells and MSYS2 programs. Double-check Task Manager and kill `pacman.exe` it's still running after the window is closed, because it can linger. Once all are closed, start a new terminal again. - It might happen that the packages are downgrades. This is unfortunate but if you want the authentic Git for Windows experience, it's necessary. + It might happen that some packages are downgraded. This is unfortunate but if you want the authentic Git for Windows experience, it's necessary. 6. Then synchronize *again* (updating the non-core part of the packages): pacman -Suu - 7. And finally install the Git/cURL packages: + 7. And finally install the packages containing Git, its documentation and some environment modifications: - pacman -S mingw-w64-x86_64-{git,git-doc-html,git-doc-man,curl} git-extra + pacman -S mingw-w64-x86_64-{git,git-doc-html,git-doc-man} git-extra 8. Close the current shell and open a MINGW64 shell (`msys2_shell.cmd -mingw64`). From f5af33f74b2f62ce7b215cc2195609fde43fd694 Mon Sep 17 00:00:00 2001 From: David Macek Date: Sat, 22 May 2021 12:00:06 +0200 Subject: [PATCH 486/591] Streamline steps --- Install-inside-MSYS2-proper.md | 45 ++++++++++++++++++---------------- 1 file changed, 24 insertions(+), 21 deletions(-) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index 12aba01899f641..abf330a34cc9fb 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -1,56 +1,59 @@ # **Please note that this scenario is not officially supported by Git for Windows** -If you need help with the installation steps, you can contact @Elieux on the `git-for-windows/git` Gitter room or on the `#msys2` IRC channel. Please don't file issues with Git for Windows installed this way until you verify them in an official Git for Windows distribution. +Git for Windows being based on MSYS2, it's possible to install the `mingw-w64-git` package into an existing MSYS2 installation. That means that if you are already using MSYS2 on your computer, you can use Git for Windows without running the full installer or using the portable version. There are some caveats for going this way, details below. -**This guide assumes that you want the 64-bit version of Git for Windows.** +This guide assumes you are comfortable using the command line and you are willing to completely re-install your MSYS2 if something goes wrong. You can contact @Elieux for advice in the `git-for-windows/git` Gitter room or through the contact channels for MSYS2. Please don't file issues with Git for Windows installed this way until you verify them in an official Git for Windows distribution. -Git for Windows being based on MSYS2, it's possible to install the `mingw-w64-git` package into an existing MSYS2 installation. That means that if you are already using MSYS2 on your computer, you can use Git for Windows without running the full installer or using the portable version. -Note however that there are some caveats for going this way. Git for Windows created some patches for `msys2-runtime` that have not been sent upstream. (This had been planned, but it was determined in issue [#284](/git-for-windows/git/issues/284) that it would probably not be happening.) This means that you have to install Git for Windows customized `msys2-runtime` to have a fully working `git` inside MSYS2. +#### The steps -Here the steps to take: +Here are the steps to install the 64-bit version of Git for Windows to be run in an MSYS2 terminal (`msys2_shell.cmd`): - 1. Open an MSYS2 terminal with `msys2_shell.cmd`. - 2. Edit `/etc/pacman.conf` and just before `[mingw32]` (line #71 on my machine), add the `git-for-windows` packages repository: + 1. Edit `/etc/pacman.conf` and add the Git for Windows package repositories above any others (i.e. just before `[mingw32]` on line #71 as of this writing): [git-for-windows] Server = https://wingit.blob.core.windows.net/x86-64 - and optionally also the MINGW-only repository for the *opposite* architecture (i.e. MINGW32 for 64-bit SDK): - [git-for-windows-mingw32] Server = https://wingit.blob.core.windows.net/i686 - If you are comfortable with command line and the `sed` command, the step 2 can be done with the following `sed` command (make sure to do proper backup before trying it): + (The above is correct. The second, MINGW-only repository is for the other architecture.) + + This step can be done with the following `sed` command (make sure to do proper backup before trying it): - sed -i '/^\[mingw32\]/{ s|^|[git-for-windows]\nServer = https://wingit.blob.core.windows.net/x86-64\n\n|; }' /etc/pacman.conf + sed -i '/^\[mingw32\]/{ s|^|[git-for-windows]\nServer = https://wingit.blob.core.windows.net/x86-64\n\n[git-for-windows-mingw32]\nServer = https://wingit.blob.core.windows.net/i686\n\n|; }' /etc/pacman.conf - 3. Authorize signing key with: + 2. Authorize the signing key with: curl -L https://raw.githubusercontent.com/git-for-windows/build-extra/HEAD/git-for-windows-keyring/git-for-windows.gpg | pacman-key --add - && pacman-key --lsign-key 3B6D86A1BA7701CD0F23AED888138B9E1A9F3986 - 4. Then synchronize new repository with + 3. Then synchronize with new repositories with pacman -Syyuu - 5. This updates `msys2-runtime` and therefore will ask you to close the window (*not* just exit the pacman process). Don't panic, simply close all currently open MSYS2 shells and MSYS2 programs. Double-check Task Manager and kill `pacman.exe` it's still running after the window is closed, because it can linger. Once all are closed, start a new terminal again. + This installs a new `msys2-runtime` and therefore will ask you to terminate all MSYS2 processes. Save what you need from other open MSYS2 shells and programs, exit them and confirm the Pacman prompt. + Double-check Task Manager and kill `pacman.exe` if it's still running after the window is closed. Start a new MSYS2 terminal. - It might happen that some packages are downgraded. This is unfortunate but if you want the authentic Git for Windows experience, it's necessary. - - 6. Then synchronize *again* (updating the non-core part of the packages): + 4. Then synchronize *again* (updating the non-core part of the packages): pacman -Suu - 7. And finally install the packages containing Git, its documentation and some environment modifications: + 5. And finally install the packages containing Git, its documentation and some environment modifications[2]: pacman -S mingw-w64-x86_64-{git,git-doc-html,git-doc-man} git-extra - 8. Close the current shell and open a MINGW64 shell (`msys2_shell.cmd -mingw64`). +Now you can close the current shell and open a MINGW64 shell (`msys2_shell.cmd -mingw64`) to check that everything went well. Run `git --version` and it should output something like `git version 2.31.0.windows.1` (or newer). - 9. Finally, check that everything went well by doing `git --version` and it should output something like `git version 2.14.1.windows.1` (or newer). #### Troubleshooting -If you encounter error "*error: wrong number of arguments, should be from 1 to 2*" with `git add -p`, set `add.interactive.useBuiltin` to `true`. +If you encounter error "*error: wrong number of arguments, should be from 1 to 2*" with `git add -p`, set `add.interactive.useBuiltin` to `true` in Git's configuration. + + +#### Notes + +Git for Windows carries an `msys2-runtime` different from upstream MSYS2, see issue [#284](/git-for-windows/git/issues/284) for more details. The steps above do install the custom version to ensure you have a fully working Git. + +It might happen that some packages are downgraded compared to upstream MSYS2. This is unfortunate but if you want the authentic Git for Windows experience, it's necessary. From ec1aed160bcefbd1c658e615e9c1e7b7d875f4b0 Mon Sep 17 00:00:00 2001 From: David Macek Date: Sat, 22 May 2021 12:01:29 +0200 Subject: [PATCH 487/591] Note that msys2-runtime can be kept --- Install-inside-MSYS2-proper.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index abf330a34cc9fb..eff312e79133e0 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -54,6 +54,6 @@ If you encounter error "*error: wrong number of arguments, should be from 1 to 2 #### Notes -Git for Windows carries an `msys2-runtime` different from upstream MSYS2, see issue [#284](/git-for-windows/git/issues/284) for more details. The steps above do install the custom version to ensure you have a fully working Git. +Git for Windows carries an `msys2-runtime` different from upstream MSYS2, see issue [#284](/git-for-windows/git/issues/284) for more details. It's possible to keep the stock MSYS2 runtime by reordering the repositories in `/etc/pacman.conf`. The steps above do install the custom version to ensure you have a fully working Git. In either case it's possible to run into issues, although not common. It might happen that some packages are downgraded compared to upstream MSYS2. This is unfortunate but if you want the authentic Git for Windows experience, it's necessary. From 0a7da4f31707e5180012e7f570fcda5d51112753 Mon Sep 17 00:00:00 2001 From: David Macek Date: Sat, 22 May 2021 12:02:00 +0200 Subject: [PATCH 488/591] Run Git from outside the shells --- Install-inside-MSYS2-proper.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index eff312e79133e0..7f82a0967c8d73 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -46,6 +46,8 @@ Here are the steps to install the 64-bit version of Git for Windows to be run in Now you can close the current shell and open a MINGW64 shell (`msys2_shell.cmd -mingw64`) to check that everything went well. Run `git --version` and it should output something like `git version 2.31.0.windows.1` (or newer). +If you want to run Git from outside the shells, add `C:\msys64\cmd` to your `PATH`, e.g. by using *Edit environment variables for your account* from the Start menu. It has to come before any other entry pointing inside your MSYS2 installation. If you have installed your MSYS2 into a different directory, correct the path accordingly. + #### Troubleshooting From 2ecf41236221994c6474f36173e433b8d4cf730f Mon Sep 17 00:00:00 2001 From: David Macek Date: Sat, 22 May 2021 12:13:37 +0200 Subject: [PATCH 489/591] Explain downgraded packages better --- Install-inside-MSYS2-proper.md | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index 7f82a0967c8d73..c58806f2c2a2c0 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -36,10 +36,12 @@ Here are the steps to install the 64-bit version of Git for Windows to be run in This installs a new `msys2-runtime` and therefore will ask you to terminate all MSYS2 processes. Save what you need from other open MSYS2 shells and programs, exit them and confirm the Pacman prompt. Double-check Task Manager and kill `pacman.exe` if it's still running after the window is closed. Start a new MSYS2 terminal. - 4. Then synchronize *again* (updating the non-core part of the packages): + 4. Then synchronize *again* to install the rest: pacman -Suu + It might happen that some packages are downgraded, this is expected. + 5. And finally install the packages containing Git, its documentation and some environment modifications[2]: pacman -S mingw-w64-x86_64-{git,git-doc-html,git-doc-man} git-extra @@ -58,4 +60,4 @@ If you encounter error "*error: wrong number of arguments, should be from 1 to 2 Git for Windows carries an `msys2-runtime` different from upstream MSYS2, see issue [#284](/git-for-windows/git/issues/284) for more details. It's possible to keep the stock MSYS2 runtime by reordering the repositories in `/etc/pacman.conf`. The steps above do install the custom version to ensure you have a fully working Git. In either case it's possible to run into issues, although not common. -It might happen that some packages are downgraded compared to upstream MSYS2. This is unfortunate but if you want the authentic Git for Windows experience, it's necessary. +Git for Windows also patches some other packages like cURL and OpenSSL. It unfortunately sometimes causes some packages to be behind in terms of their version, but keeping the upstream packages would most probably lead to a severely broken Git. From 030ac2b6eba2b680ab435d6d0b5da25a123017d3 Mon Sep 17 00:00:00 2001 From: David Macek Date: Sat, 22 May 2021 12:52:10 +0200 Subject: [PATCH 490/591] Let's talk about git-extra --- Install-inside-MSYS2-proper.md | 18 +++++++++++++++++- 1 file changed, 17 insertions(+), 1 deletion(-) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index c58806f2c2a2c0..e0c7d3da802f54 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -42,7 +42,7 @@ Here are the steps to install the 64-bit version of Git for Windows to be run in It might happen that some packages are downgraded, this is expected. - 5. And finally install the packages containing Git, its documentation and some environment modifications[2]: + 5. And finally install the packages containing Git, its documentation and some extra things: pacman -S mingw-w64-x86_64-{git,git-doc-html,git-doc-man} git-extra @@ -61,3 +61,19 @@ If you encounter error "*error: wrong number of arguments, should be from 1 to 2 Git for Windows carries an `msys2-runtime` different from upstream MSYS2, see issue [#284](/git-for-windows/git/issues/284) for more details. It's possible to keep the stock MSYS2 runtime by reordering the repositories in `/etc/pacman.conf`. The steps above do install the custom version to ensure you have a fully working Git. In either case it's possible to run into issues, although not common. Git for Windows also patches some other packages like cURL and OpenSSL. It unfortunately sometimes causes some packages to be behind in terms of their version, but keeping the upstream packages would most probably lead to a severely broken Git. + +The `git-extra` package modifies the MSYS2 environment heavily (sometimes in ways that are tedious to undo). The package can be skipped if you want to keep your MSYS2 pristine. As of this writing, the package: + +- brings the `git-for-windows-keyring` package as its dependency, but you can install it manually +- adds the `sdk` command intended for developing Git for Windows +- installs some update helpers (`update-via-pacman`, `git update-git-for-windows`) but you can still use the regular `pacman -Syu` +- installs various other helpers: `blocked-file-util`, `create-shortcut`, `git-askyesno`, `git-credential-helper-selector`, `proxy-lookup`, `WhoUses`, `astextplain`, `notepad`, `vi`, `wordpad` +- changes configuration for Pacman, Bash/Sh, Vim, Nano, Readline, OpenSSH and Git itself (`/etc/gitconfig`, `/etc/gitattributes`) +- changes the MSYS2-to-Windows integration settings in `/etc/nsswitch.conf` and `/etc/fstab` and inherits outside `PATH` by default +- may create a `.bash_profile` in your home directory +- may delete, modify or replace `/msys2.ico`, `/usr/bin/start`, `/mingw/*-w64-mingw32/include/pthread_unistd.h`, `/ssl` +- deletes, modifies and replaces some files in `/mingw??/bin/` and `/mingw??/libexec/git-core/` +- changes the terminal window title, changes the shell prompt +- enables a GUI SSH password prompt +- automatically wraps some interactive non-msys programs using `winpty`: Node, Python, PHP, PostgreSQL +- adds support for ARM64 From b503154dcd28cfdd2f52386147f9b6d9c44292a7 Mon Sep 17 00:00:00 2001 From: David Macek Date: Tue, 25 May 2021 08:53:22 +0200 Subject: [PATCH 491/591] Updated Install inside MSYS2 proper (markdown) --- Install-inside-MSYS2-proper.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index e0c7d3da802f54..0ae79afe1927d3 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -58,7 +58,7 @@ If you encounter error "*error: wrong number of arguments, should be from 1 to 2 #### Notes -Git for Windows carries an `msys2-runtime` different from upstream MSYS2, see issue [#284](/git-for-windows/git/issues/284) for more details. It's possible to keep the stock MSYS2 runtime by reordering the repositories in `/etc/pacman.conf`. The steps above do install the custom version to ensure you have a fully working Git. In either case it's possible to run into issues, although not common. +Git for Windows carries an `msys2-runtime` different from upstream MSYS2, see [issue #284](https://github.com/git-for-windows/git/issues/284) for more details. You can run into some rare issues with programs other than Git due to this. It's possible to keep the stock MSYS2 runtime by moving the `msys` repository above the `git-for-windows` repository in `/etc/pacman.conf`. There are known issues with Git in that case, although not common. Git for Windows also patches some other packages like cURL and OpenSSL. It unfortunately sometimes causes some packages to be behind in terms of their version, but keeping the upstream packages would most probably lead to a severely broken Git. From 8d474edc124535ab1f9e7cb4b4c59e9cd5b20f49 Mon Sep 17 00:00:00 2001 From: Geoffrey-A Date: Fri, 18 Jun 2021 16:25:49 +1200 Subject: [PATCH 492/591] Add mention of the git-credential-manager package --- Install-inside-MSYS2-proper.md | 3 +++ 1 file changed, 3 insertions(+) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index 0ae79afe1927d3..6492b999ea76ba 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -50,6 +50,9 @@ Now you can close the current shell and open a MINGW64 shell (`msys2_shell.cmd - If you want to run Git from outside the shells, add `C:\msys64\cmd` to your `PATH`, e.g. by using *Edit environment variables for your account* from the Start menu. It has to come before any other entry pointing inside your MSYS2 installation. If you have installed your MSYS2 into a different directory, correct the path accordingly. +To integrate with the Windows Credential Manager, install the package `git-credential-manager`, then tell git to use it with + + git config --global credential.helper manager #### Troubleshooting From 8e48ccd531c1ec4543453d62b0fe2822371fad2b Mon Sep 17 00:00:00 2001 From: Geoffrey-A Date: Sat, 19 Jun 2021 01:01:29 +1200 Subject: [PATCH 493/591] Add how to get `git help` work with man pages --- Install-inside-MSYS2-proper.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index 6492b999ea76ba..54c80c15f9ded8 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -50,9 +50,9 @@ Now you can close the current shell and open a MINGW64 shell (`msys2_shell.cmd - If you want to run Git from outside the shells, add `C:\msys64\cmd` to your `PATH`, e.g. by using *Edit environment variables for your account* from the Start menu. It has to come before any other entry pointing inside your MSYS2 installation. If you have installed your MSYS2 into a different directory, correct the path accordingly. -To integrate with the Windows Credential Manager, install the package `git-credential-manager`, then tell git to use it with +To integrate with the Windows Credential Manager, install the package `git-credential-manager`, then tell git to use it with `git config --global credential.helper manager`. - git config --global credential.helper manager +To be able to view the git man pages when invoking help with `git help X` or `git X --help` (in addition to `man git-X`), add the line `export MSYS2_ENV_CONV_EXCL=MANPATH` to your shell configuration, and set the man pages as default help format with `git config --global help.format man` (or append `-m` to the git help invocation). #### Troubleshooting From dcf057710d5b3e6f0c6f7719c3fbe7a70bc6e631 Mon Sep 17 00:00:00 2001 From: Zhai Dev <29057533+zdevcs@users.noreply.github.com> Date: Fri, 30 Jul 2021 11:36:36 +0800 Subject: [PATCH 494/591] Git Credential Manager for Windows is no longer being maintained. The cross-platform Git Credential Manager Core (GCM Core) is the official replacement. --- Install-inside-MSYS2-proper.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index 54c80c15f9ded8..11e3dfca973da5 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -50,7 +50,7 @@ Now you can close the current shell and open a MINGW64 shell (`msys2_shell.cmd - If you want to run Git from outside the shells, add `C:\msys64\cmd` to your `PATH`, e.g. by using *Edit environment variables for your account* from the Start menu. It has to come before any other entry pointing inside your MSYS2 installation. If you have installed your MSYS2 into a different directory, correct the path accordingly. -To integrate with the Windows Credential Manager, install the package `git-credential-manager`, then tell git to use it with `git config --global credential.helper manager`. +To integrate with the Windows Credential Manager, install the package `git-credential-manager-core`. To be able to view the git man pages when invoking help with `git help X` or `git X --help` (in addition to `man git-X`), add the line `export MSYS2_ENV_CONV_EXCL=MANPATH` to your shell configuration, and set the man pages as default help format with `git config --global help.format man` (or append `-m` to the git help invocation). From 3f463613fdf40c246de21bb60b9380e01c0a1ef5 Mon Sep 17 00:00:00 2001 From: TaleTN Date: Wed, 18 Aug 2021 09:47:44 +0200 Subject: [PATCH 495/591] Updated Building msys2 runtime (markdown) --- Building-msys2-runtime.md | 18 +++++++----------- 1 file changed, 7 insertions(+), 11 deletions(-) diff --git a/Building-msys2-runtime.md b/Building-msys2-runtime.md index 714d0dd180c785..59dd8adb116fcc 100644 --- a/Building-msys2-runtime.md +++ b/Building-msys2-runtime.md @@ -1,20 +1,16 @@ # Installing a build environment -1. Just run the [SDK installer](https://gitforwindows.org/#download-sdk). +1. Download and run the [Windows SDK installer](https://gitforwindows.org/#download-sdk). -# Build `msys2-runtime` +# Building msys2-runtime -1. Open the *Git for Windows SDK* *MSys* shell by launching `msys2_shell.cmd` with option `-msys` in the install folder. (i.e. not the *MinGW 32-bit* nor the *MinGW 64-bit* one). +2. Open the Git for Windows SDK MSys shell by double-clicking the `msys2_shell.cmd` script in the install folder (by default `C:\git-sdk-`). -2. Install the MSYS2 Toolchain: `pacman -S msys2-devel base-devel`. +3. From the MSys shell do: `sdk build msys2-runtime` -3. Initialize the local MSYS2-packages clone: `cd /usr/src/MSYS2-packages && git fetch origin && git checkout main`. +This last step may take a while, so please be patient! -4. Change to the `msys2-runtime` directory: `cd msys2-runtime` - -5. Build the package: `makepkg -s`. - -# Rebuild the msys2-runtime +# Rebuilding the msys2-runtime When there are bugs in the msys2-runtime (e.g. problems with the POSIX-to-Windows path mangling), you need to rebuild the `msys-2.0.dll`, possibly frequently. @@ -24,4 +20,4 @@ To actually build the `msys-2.0.dll`, switch to `src/build--pc-msys/ # Related: building/rebuilding Bash -The process to rebuild the `Bash` is very similar to the `msys2-runtime` one; You will just need to work in the `src/bash-/` subdirectory of `/usr/src/MSYS2-packages/bash/` (both the sources and the generated `bash.exe` live there). Bash also requires all Bash instances to be exited before the executable is replaced by the new one. And like with the msys2-runtime, you will **want** to make a backup copy of the old `bash.exe`. +The process to rebuild the `Bash` is very similar to the `msys2-runtime` one; You will just need to work in the `src/bash-/` subdirectory of `/usr/src/MSYS2-packages/bash/` (both the sources and the generated `bash.exe` live there). Bash also requires all Bash instances to be exited before the executable is replaced by the new one. And like with the msys2-runtime, you will **want** to make a backup copy of the old `bash.exe`. \ No newline at end of file From 5aba1208f2a900b5f539d3507df3d7a93a9475cb Mon Sep 17 00:00:00 2001 From: TaleTN Date: Wed, 18 Aug 2021 09:49:01 +0200 Subject: [PATCH 496/591] Updated Building msys2 runtime (markdown) --- Building-msys2-runtime.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Building-msys2-runtime.md b/Building-msys2-runtime.md index 59dd8adb116fcc..c15563af143736 100644 --- a/Building-msys2-runtime.md +++ b/Building-msys2-runtime.md @@ -1,6 +1,6 @@ # Installing a build environment -1. Download and run the [Windows SDK installer](https://gitforwindows.org/#download-sdk). +1. Download and run the [Git for Windows SDK installer](https://gitforwindows.org/#download-sdk). # Building msys2-runtime From 08ad44024fbf58f8eb1e68ef10d5e52a37fe743d Mon Sep 17 00:00:00 2001 From: David Bruchmann Date: Fri, 27 Aug 2021 04:23:03 +0700 Subject: [PATCH 497/591] add method to the update section --- Updating-your-SDK.md | 14 ++++++++++++++ 1 file changed, 14 insertions(+) diff --git a/Updating-your-SDK.md b/Updating-your-SDK.md index 7b91f5ce54602a..ebca9a07048787 100644 --- a/Updating-your-SDK.md +++ b/Updating-your-SDK.md @@ -14,6 +14,20 @@ plus Git for Windows' packages. # Updating the installed SDK +The most simple was to update git is to open the git-shell and type the command +``` +git update +``` +The shown response is this: +``` +Warning! `git update` has been deprecated; +Please use `git update-git-for-windows` instead. +``` +Depending on the version you still have the option to follow this deprecated command by typing `y` for yes or just interrupt it by typing `n` for no. +Either the old command or the new command `git update-git-for-windows`, both offer to install the new version and do the update without problems usually. + +Alternative ways to update are shown below (they might be outdated perhaps): + The SDK ships with the script `update-via-pacman.bat` that you can: 1. Make sure that all Git SDK Bash windows are closed first, From 4449936fb80b8ece0a02b2219f43fa28a29c131e Mon Sep 17 00:00:00 2001 From: David Bruchmann Date: Fri, 27 Aug 2021 04:23:54 +0700 Subject: [PATCH 498/591] Updated Updating your SDK (markdown) --- Updating-your-SDK.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Updating-your-SDK.md b/Updating-your-SDK.md index ebca9a07048787..460ed546b48b5d 100644 --- a/Updating-your-SDK.md +++ b/Updating-your-SDK.md @@ -14,7 +14,7 @@ plus Git for Windows' packages. # Updating the installed SDK -The most simple was to update git is to open the git-shell and type the command +The most simple way to update git is to open the git-shell and type the command ``` git update ``` From e2f09d84c7e05bb849f37ea2b8c5e424d7afd9cc Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Matthias=20A=C3=9Fhauer?= Date: Fri, 27 Aug 2021 05:45:45 +0200 Subject: [PATCH 499/591] Revert 5aba1208f2a900b5f539d3507df3d7a93a9475cb...4449936fb80b8ece0a02b2219f43fa28a29c131e --- Updating-your-SDK.md | 14 -------------- 1 file changed, 14 deletions(-) diff --git a/Updating-your-SDK.md b/Updating-your-SDK.md index 460ed546b48b5d..7b91f5ce54602a 100644 --- a/Updating-your-SDK.md +++ b/Updating-your-SDK.md @@ -14,20 +14,6 @@ plus Git for Windows' packages. # Updating the installed SDK -The most simple way to update git is to open the git-shell and type the command -``` -git update -``` -The shown response is this: -``` -Warning! `git update` has been deprecated; -Please use `git update-git-for-windows` instead. -``` -Depending on the version you still have the option to follow this deprecated command by typing `y` for yes or just interrupt it by typing `n` for no. -Either the old command or the new command `git update-git-for-windows`, both offer to install the new version and do the update without problems usually. - -Alternative ways to update are shown below (they might be outdated perhaps): - The SDK ships with the script `update-via-pacman.bat` that you can: 1. Make sure that all Git SDK Bash windows are closed first, From c6cf1caed952197b5050f39361fc2d45e1d0f58f Mon Sep 17 00:00:00 2001 From: Beltran1161 <89534996+Beltran1161@users.noreply.github.com> Date: Mon, 30 Aug 2021 05:55:21 -0500 Subject: [PATCH 500/591] Destroyed FAQ (markdown) --- FAQ.md | 123 --------------------------------------------------------- 1 file changed, 123 deletions(-) delete mode 100644 FAQ.md diff --git a/FAQ.md b/FAQ.md deleted file mode 100644 index 50295883bf122a..00000000000000 --- a/FAQ.md +++ /dev/null @@ -1,123 +0,0 @@ -## Which versions of Windows are supported? - -Git for Windows currently works with all recent, commercially released x86 32 bit and 64 bit versions of Windows, starting with Windows Vista. - -*** -NOTE: Git for Windows version [2.10.0](https://github.com/git-for-windows/git/releases/tag/v2.10.0.windows.1) was the last version supporting Windows XP and Server 2003. -*** - -Windows XP and Windows Server 2003 are long past their end of life, hence support for these versions was dropped from Git for Windows 2.10.1 and later. This limitation is inherited by Git's use of MSYS2, which in turn inherited it from [Cygwin](https://cygwin.com/ml/cygwin/2015-08/msg00446.html). - -More information here: [Git for Windows' prerequisites](https://gitforwindows.org/requirements.html). - -## Is there an MSI for installation via Group Policy? - -There is currently no MSI package; there is an exe installer and a portable package. You are welcome to contribute a Pull Request that packages a new installer. - -~There is an existing Pull Request in development and looking for testers, please try out https://github.com/robmen/gitsetup/issues/1 and give feedback.~ It's closed by now. Future development is happening [here](https://github.com/git-for-windows/build-extra/tree/HEAD/msi/). - -In the meantime you could try: - - * using the portable package - * deploying the exe installer with System Center Configuration Manager - * deploying the portable package via a script - * deploying the Chocolatey package via Puppet (or something similar) - -## Should I upgrade to a newer Git for Windows version? - -In general, yes: it is a good idea to stay up-to-date. - -If you have a version older than 2.30.2, it is *highly* advisable to upgrade. A couple of Git versions came with important fixes to security-relevant vulnerabilities: 2.30.2, 2.30.0(2), 2.29.2(3), 2.29.2(2), 2.26.1, 2.24.1(2), 2.17.1(2), 2.14.1, 2.7.4, 2.7.0, 2.6.1, 2.5.2, 1.9.5-preview20150319, and 1.9.5-preview20141217. - -## What is the release cadence of Git for Windows? - -Official Git for Windows versions mainly follow Git's release cycle: every 12 weeks or so, a new major Git version is released (see details here: https://tinyurl.com/gitCal). Typically, Git for Windows will follow suit within a day. - -Other than that, Git for Windows follows the *newest* Git version's maintenance releases (read: after Git for Windows v2.15.0 was released, no new Git for Windows v2.14.x version would be released). Indicators for imminent maintenance releases of Git are: - -- The Git maintainer sometimes talks about this in the preamble of the ["What's cooking in git.git" mails](https://public-inbox.org/git/?q=s%3A%22what%27s+cooking%22+AND+f%3Agitster%40pobox.com). -- The [`maint` in git.git](https://github.com/git/git/commits/maint) accumulates critical patches. - -Finally, Git for Windows is sometimes released in "out-of-band" versions, when critical fixes specific to Git for Windows necessitate it. These out-of-band versions are indicated by appending a `(2)` to the latest release (or `(3)`, `(4)`, etc). Examples for such out-of-band versions include: [Git for Windows v2.15.1(2)](https://github.com/git-for-windows/git/releases/tag/v2.15.1.windows.2) and [Git for Windows v2.16.1(4)](https://github.com/git-for-windows/git/releases/tag/v2.16.1.windows.4). - -## What is the relationship between *Git for Windows* and *msysGit*? - -*Git for Windows* used to be developed using the development environment called "msysGit", but roughly coinciding with Git 2.1, msysGit was superseded by a new development environment: the [Git for Windows SDK](https://github.com/git-for-windows/build-extra/releases). See [here](https://github.com/git-for-windows/git/wiki/Updating-your-SDK) to get a copy. - -## How do I update *Git for Windows* upon new releases? - -This depends on how you installed *Git for Windows*. The bundle installation requires you to download and install the new version. Any customizations you made will be kept as long as you did so in the appropriate configuration folders. - -For advanced users working with the *Git for Windows* SDK `pacman` is available as a package manager. See [Package management](Package-management) - -## How do I check the release hash and release notes - -For hashes see https://github.com/git-for-windows/git/releases - -For (G4W) release notes see the [build-extra repo](https://github.com/git-for-windows/build-extra/blob/HEAD/ReleaseNotes.md), or the top level of your installation (e.g. [C:\Program Files\Git\ReleaseNotes.html](https://www.example.com/Program%20Files/Git/ReleaseNotes.html) - via manual browsing). - -For extracting 7z/zip archives see [page](https://github.com/git-for-windows/git/wiki/Zip-Archives---extracting-the-released-archives). - -## Are there 'Nightly' builds of the latest and greatest - -The Git for Windows builds are not quite that frequent, but there are Snapshot builds listed at https://wingit.blob.core.windows.net/files/index.html - -These often 'fix' (or attempt fixes) recent issues before a new formal release. Check their commit notes and links to issues to see if your problem is included. - -## Some native console programs don't work when run from Git Bash. How to fix it? - -*Git for Windows* defaults to using [mintty](https://code.google.com/p/mintty/) terminal. Compared to default Windows console host, it provides normal multi-line cut&paste, working resizing, defaults to unicode font and avoids some bugs in the default console host. However it does not present itself as console to native applications (those *not* built with MSys or Cygwin), so in these applications: - - * Non-ASCII output may be corrupted due to mismatch in character sets (MSYS2 and Cygwin use UTF-8 while Windows will fall back to the legacy DOS codepages in this case). - * Interactive and full-screen applications won't work at all. - -There are several methods for working around these problems: - - * Run programs that have problems using the [`winpty`](https://github.com/rprichard/winpty) utility. This allows you to keep using the nicer mintty terminal, but can become unwieldy if you need the workaround for many programs. - * Modify the shortcut for Git Bash to run `bash` directly without `mintty` so it uses the default console host and configure it for "Quick Edit", reasonable size and scroll-back and suitable unicode font. You'll still have to live with the other quirks of console host. - * Install and use [ConEmu](https://conemu.github.io/). - -## I get errors trying to check out files with long path names. -Windows file paths are by default limited to 255 characters. Some repositories may have committed files which contain paths longer than the limit. By default, *Git for Windows* does not support long paths, and will print errors when trying to perform any operation on a long file name. Set the configuration property `core.longpaths` to true to allow certain Git operations to properly handle these files. See [this wiki page](https://github.com/git-for-windows/git/wiki/Git-cannot-create-a-file-or-directory-with-a-long-path) for more information. - -## The installed files are duplicated and look massive - Why? -All the apparent copies are simply hard links - see Issue 1997 [Use symbolic links for libexec](https://github.com/git-for-windows/git/issues/1997) for more details. - -## Excel file modifications not always noticed. -Excel (and some other apps) do not update the *modified time* of its files which is used by Git to quickly detect changes. Rather Excel used the *change time* field. Git will notice the modifications if a `git status` is performed. See [issue 1000](https://github.com/git-for-windows/git/issues/1000#issuecomment-301611003) if you need more background. - -## How do I access a repository hosted on a Microsoft Team Foundation Server inside a Windows domain? - -The Microsoft Team Foundation Server is capable of hosting git repositories. If the server is a member of a windows domain, and your user account is in that domain, you can use domain authentication to identify yourself to the server, and can thus access git repositories without having to enter any credentials. For this to work, the server has to be configured to use domain authentication, _not_ NTLM authentication. The repository URL can be obtained from the TFS web interface, it may look like http://server.example.com:8080/tfs/TWA/TeamDev/_git/reponame. - -In order to instruct git to use domain authentication, prefix the server name with `:@`, like so: `http://:@server.example.com:8080/tfs/TWA/TeamDev/_git/reponame`. This is a special case of the usual `username:password@server` syntax, where both the `username` and `password` fields are empty. This causes git to look up and use your domain credentials. - -See also: [Clone an existing Git repo - Azure Repos](https://docs.microsoft.com/en-us/azure/devops/repos/git/clone) - -## I get "Permission denied (publickey)." when using git pull - -Some DSA keys are not considered secure anymore by OpenSSH 7. Adding "PubkeyAcceptedKeyTypes ssh-dss" to ~/.ssh/config helps. - -## Switch locale for git-bash launcher (of Git for Windows SDK) - -Some developers want to start git-bash (of Git for Windows SDK) with a different language. -To achieve this in windows following command could be placed inside the launcher: -`C:\Windows\System32\cmd.exe /c "set LANG=en_GB && start C:\git-sdk-64\git-bash.exe && exit"` -replace `en_GB` with your preferred locale. - -## I have errors while building the solution in Visual studio -(i.e. `fatal error C1083: Cannot open include file: 'openssl/ssl.h': No such file or directory`) - -Try to open the console and invoke `git\compat\vcbuild\vcpkg_install.bat`. Make sure that it has completed successfully, then clean and rebuild the solution. - -Ensure also that you are using proper Build Tools (v140). It's going by default in VS 2015. If you are using VS 2017, you need to install them manually. Do not upgrade the project to v141 - it can't be done automatically. - -## Licenses - -Reproduced from [Git for Windows' release notes](https://github.com/git-for-windows/build-extra/blob/HEAD/ReleaseNotes.md#licenses): - -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. - -Git for Windows also contains Embedded CAcert Root Certificates. For more information please go to https://www.cacert.org/policy/RootDistributionLicense.php. - -This package contains software from a number of other projects including Bash, zlib, curl, tcl/tk, perl, MSYS2 and a number of libraries and utilities from the GNU project, licensed under the GNU General Public License. Likewise, it contains Perl which is dual licensed under the GNU General Public License and the Artistic License. From 057472046f95eba1c4cd3b5c81b756e833f25721 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Matthias=20A=C3=9Fhauer?= Date: Wed, 1 Sep 2021 09:50:10 +0200 Subject: [PATCH 501/591] Revert e2f09d84c7e05bb849f37ea2b8c5e424d7afd9cc...c6cf1caed952197b5050f39361fc2d45e1d0f58f --- FAQ.md | 123 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 123 insertions(+) create mode 100644 FAQ.md diff --git a/FAQ.md b/FAQ.md new file mode 100644 index 00000000000000..50295883bf122a --- /dev/null +++ b/FAQ.md @@ -0,0 +1,123 @@ +## Which versions of Windows are supported? + +Git for Windows currently works with all recent, commercially released x86 32 bit and 64 bit versions of Windows, starting with Windows Vista. + +*** +NOTE: Git for Windows version [2.10.0](https://github.com/git-for-windows/git/releases/tag/v2.10.0.windows.1) was the last version supporting Windows XP and Server 2003. +*** + +Windows XP and Windows Server 2003 are long past their end of life, hence support for these versions was dropped from Git for Windows 2.10.1 and later. This limitation is inherited by Git's use of MSYS2, which in turn inherited it from [Cygwin](https://cygwin.com/ml/cygwin/2015-08/msg00446.html). + +More information here: [Git for Windows' prerequisites](https://gitforwindows.org/requirements.html). + +## Is there an MSI for installation via Group Policy? + +There is currently no MSI package; there is an exe installer and a portable package. You are welcome to contribute a Pull Request that packages a new installer. + +~There is an existing Pull Request in development and looking for testers, please try out https://github.com/robmen/gitsetup/issues/1 and give feedback.~ It's closed by now. Future development is happening [here](https://github.com/git-for-windows/build-extra/tree/HEAD/msi/). + +In the meantime you could try: + + * using the portable package + * deploying the exe installer with System Center Configuration Manager + * deploying the portable package via a script + * deploying the Chocolatey package via Puppet (or something similar) + +## Should I upgrade to a newer Git for Windows version? + +In general, yes: it is a good idea to stay up-to-date. + +If you have a version older than 2.30.2, it is *highly* advisable to upgrade. A couple of Git versions came with important fixes to security-relevant vulnerabilities: 2.30.2, 2.30.0(2), 2.29.2(3), 2.29.2(2), 2.26.1, 2.24.1(2), 2.17.1(2), 2.14.1, 2.7.4, 2.7.0, 2.6.1, 2.5.2, 1.9.5-preview20150319, and 1.9.5-preview20141217. + +## What is the release cadence of Git for Windows? + +Official Git for Windows versions mainly follow Git's release cycle: every 12 weeks or so, a new major Git version is released (see details here: https://tinyurl.com/gitCal). Typically, Git for Windows will follow suit within a day. + +Other than that, Git for Windows follows the *newest* Git version's maintenance releases (read: after Git for Windows v2.15.0 was released, no new Git for Windows v2.14.x version would be released). Indicators for imminent maintenance releases of Git are: + +- The Git maintainer sometimes talks about this in the preamble of the ["What's cooking in git.git" mails](https://public-inbox.org/git/?q=s%3A%22what%27s+cooking%22+AND+f%3Agitster%40pobox.com). +- The [`maint` in git.git](https://github.com/git/git/commits/maint) accumulates critical patches. + +Finally, Git for Windows is sometimes released in "out-of-band" versions, when critical fixes specific to Git for Windows necessitate it. These out-of-band versions are indicated by appending a `(2)` to the latest release (or `(3)`, `(4)`, etc). Examples for such out-of-band versions include: [Git for Windows v2.15.1(2)](https://github.com/git-for-windows/git/releases/tag/v2.15.1.windows.2) and [Git for Windows v2.16.1(4)](https://github.com/git-for-windows/git/releases/tag/v2.16.1.windows.4). + +## What is the relationship between *Git for Windows* and *msysGit*? + +*Git for Windows* used to be developed using the development environment called "msysGit", but roughly coinciding with Git 2.1, msysGit was superseded by a new development environment: the [Git for Windows SDK](https://github.com/git-for-windows/build-extra/releases). See [here](https://github.com/git-for-windows/git/wiki/Updating-your-SDK) to get a copy. + +## How do I update *Git for Windows* upon new releases? + +This depends on how you installed *Git for Windows*. The bundle installation requires you to download and install the new version. Any customizations you made will be kept as long as you did so in the appropriate configuration folders. + +For advanced users working with the *Git for Windows* SDK `pacman` is available as a package manager. See [Package management](Package-management) + +## How do I check the release hash and release notes + +For hashes see https://github.com/git-for-windows/git/releases + +For (G4W) release notes see the [build-extra repo](https://github.com/git-for-windows/build-extra/blob/HEAD/ReleaseNotes.md), or the top level of your installation (e.g. [C:\Program Files\Git\ReleaseNotes.html](https://www.example.com/Program%20Files/Git/ReleaseNotes.html) - via manual browsing). + +For extracting 7z/zip archives see [page](https://github.com/git-for-windows/git/wiki/Zip-Archives---extracting-the-released-archives). + +## Are there 'Nightly' builds of the latest and greatest + +The Git for Windows builds are not quite that frequent, but there are Snapshot builds listed at https://wingit.blob.core.windows.net/files/index.html + +These often 'fix' (or attempt fixes) recent issues before a new formal release. Check their commit notes and links to issues to see if your problem is included. + +## Some native console programs don't work when run from Git Bash. How to fix it? + +*Git for Windows* defaults to using [mintty](https://code.google.com/p/mintty/) terminal. Compared to default Windows console host, it provides normal multi-line cut&paste, working resizing, defaults to unicode font and avoids some bugs in the default console host. However it does not present itself as console to native applications (those *not* built with MSys or Cygwin), so in these applications: + + * Non-ASCII output may be corrupted due to mismatch in character sets (MSYS2 and Cygwin use UTF-8 while Windows will fall back to the legacy DOS codepages in this case). + * Interactive and full-screen applications won't work at all. + +There are several methods for working around these problems: + + * Run programs that have problems using the [`winpty`](https://github.com/rprichard/winpty) utility. This allows you to keep using the nicer mintty terminal, but can become unwieldy if you need the workaround for many programs. + * Modify the shortcut for Git Bash to run `bash` directly without `mintty` so it uses the default console host and configure it for "Quick Edit", reasonable size and scroll-back and suitable unicode font. You'll still have to live with the other quirks of console host. + * Install and use [ConEmu](https://conemu.github.io/). + +## I get errors trying to check out files with long path names. +Windows file paths are by default limited to 255 characters. Some repositories may have committed files which contain paths longer than the limit. By default, *Git for Windows* does not support long paths, and will print errors when trying to perform any operation on a long file name. Set the configuration property `core.longpaths` to true to allow certain Git operations to properly handle these files. See [this wiki page](https://github.com/git-for-windows/git/wiki/Git-cannot-create-a-file-or-directory-with-a-long-path) for more information. + +## The installed files are duplicated and look massive - Why? +All the apparent copies are simply hard links - see Issue 1997 [Use symbolic links for libexec](https://github.com/git-for-windows/git/issues/1997) for more details. + +## Excel file modifications not always noticed. +Excel (and some other apps) do not update the *modified time* of its files which is used by Git to quickly detect changes. Rather Excel used the *change time* field. Git will notice the modifications if a `git status` is performed. See [issue 1000](https://github.com/git-for-windows/git/issues/1000#issuecomment-301611003) if you need more background. + +## How do I access a repository hosted on a Microsoft Team Foundation Server inside a Windows domain? + +The Microsoft Team Foundation Server is capable of hosting git repositories. If the server is a member of a windows domain, and your user account is in that domain, you can use domain authentication to identify yourself to the server, and can thus access git repositories without having to enter any credentials. For this to work, the server has to be configured to use domain authentication, _not_ NTLM authentication. The repository URL can be obtained from the TFS web interface, it may look like http://server.example.com:8080/tfs/TWA/TeamDev/_git/reponame. + +In order to instruct git to use domain authentication, prefix the server name with `:@`, like so: `http://:@server.example.com:8080/tfs/TWA/TeamDev/_git/reponame`. This is a special case of the usual `username:password@server` syntax, where both the `username` and `password` fields are empty. This causes git to look up and use your domain credentials. + +See also: [Clone an existing Git repo - Azure Repos](https://docs.microsoft.com/en-us/azure/devops/repos/git/clone) + +## I get "Permission denied (publickey)." when using git pull + +Some DSA keys are not considered secure anymore by OpenSSH 7. Adding "PubkeyAcceptedKeyTypes ssh-dss" to ~/.ssh/config helps. + +## Switch locale for git-bash launcher (of Git for Windows SDK) + +Some developers want to start git-bash (of Git for Windows SDK) with a different language. +To achieve this in windows following command could be placed inside the launcher: +`C:\Windows\System32\cmd.exe /c "set LANG=en_GB && start C:\git-sdk-64\git-bash.exe && exit"` +replace `en_GB` with your preferred locale. + +## I have errors while building the solution in Visual studio +(i.e. `fatal error C1083: Cannot open include file: 'openssl/ssl.h': No such file or directory`) + +Try to open the console and invoke `git\compat\vcbuild\vcpkg_install.bat`. Make sure that it has completed successfully, then clean and rebuild the solution. + +Ensure also that you are using proper Build Tools (v140). It's going by default in VS 2015. If you are using VS 2017, you need to install them manually. Do not upgrade the project to v141 - it can't be done automatically. + +## Licenses + +Reproduced from [Git for Windows' release notes](https://github.com/git-for-windows/build-extra/blob/HEAD/ReleaseNotes.md#licenses): + +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. + +Git for Windows also contains Embedded CAcert Root Certificates. For more information please go to https://www.cacert.org/policy/RootDistributionLicense.php. + +This package contains software from a number of other projects including Bash, zlib, curl, tcl/tk, perl, MSYS2 and a number of libraries and utilities from the GNU project, licensed under the GNU General Public License. Likewise, it contains Perl which is dual licensed under the GNU General Public License and the Artistic License. From a0abaca50798f6f72aacfbd4715a2ece7ecb3154 Mon Sep 17 00:00:00 2001 From: Sean Jacobs Date: Tue, 5 Oct 2021 21:22:11 +1100 Subject: [PATCH 502/591] Created article. It provides a brief overview & explains how to configure Git For Windows to use an external OpenSSH client. --- Using-an-external-OpenSSH-client.md | 15 +++++++++++++++ 1 file changed, 15 insertions(+) create mode 100644 Using-an-external-OpenSSH-client.md diff --git a/Using-an-external-OpenSSH-client.md b/Using-an-external-OpenSSH-client.md new file mode 100644 index 00000000000000..cd94fce76ebe75 --- /dev/null +++ b/Using-an-external-OpenSSH-client.md @@ -0,0 +1,15 @@ +## OpenSSH on Windows 10 + +Modern versions of Windows and Windows Server come with [OpenSSH](https://www.openssh.com/) installed, and available on the system PATH. By default, the OpenSSH binaries are located in `C:\WINDOWS\System32\OpenSSH\`. + +The [`ssh-agent`](https://man.openbsd.org/ssh-agent.1) is also implemented as a [Windows service](https://docs.microsoft.com/en-us/windows/win32/services/services), allowing it to be run automatically, during boot or login, and so on. + +> **NOTE:** By default the `ssh-agent` service is **disabled**, and if its use required — to manage your private keys, for instance — it will need to be explicitly enabled, and then started (or configured to start as necessary). + +## Configuring Git For Windows to use an external client + +As per [this discussion](https://github.com/git-for-windows/git/discussions/3451#discussioncomment-1424427) on the issue, during the installation of Git For Windows there is an option to utilise either the built-in [OpenSSH](https://www.openssh.com/) client, or an external client. + +In order to configure this functionality, either as a post-installation change, or to use it with the portable version of Git For Windows, the bundled OpenSSH binaries should be removed. + +> **NOTE:** This feature is still **_experimental_**. \ No newline at end of file From ca5efc07b54173290363fd96d4f4a340c2a20689 Mon Sep 17 00:00:00 2001 From: Sean Jacobs Date: Wed, 6 Oct 2021 10:31:07 +1100 Subject: [PATCH 503/591] Updated to provide more specific instructions and correct some wording. --- Using-an-external-OpenSSH-client.md | 20 +++++++++++++++++--- 1 file changed, 17 insertions(+), 3 deletions(-) diff --git a/Using-an-external-OpenSSH-client.md b/Using-an-external-OpenSSH-client.md index cd94fce76ebe75..e9c8d7077378ac 100644 --- a/Using-an-external-OpenSSH-client.md +++ b/Using-an-external-OpenSSH-client.md @@ -8,8 +8,22 @@ The [`ssh-agent`](https://man.openbsd.org/ssh-agent.1) is also implemented as a ## Configuring Git For Windows to use an external client -As per [this discussion](https://github.com/git-for-windows/git/discussions/3451#discussioncomment-1424427) on the issue, during the installation of Git For Windows there is an option to utilise either the built-in [OpenSSH](https://www.openssh.com/) client, or an external client. +> **NOTE:** This feature is still **_experimental_**. -In order to configure this functionality, either as a post-installation change, or to use it with the portable version of Git For Windows, the bundled OpenSSH binaries should be removed. +As per [this discussion](https://github.com/git-for-windows/git/discussions/3451#discussioncomment-1424427) on the issue, during the installation of Git For Windows there is an option to utilise either the built-in [OpenSSH](https://www.openssh.com/) client, or an external client. Choosing to use an external client will skip inclusion of the bundled OpenSSH binaries in the Git For Windows installation. -> **NOTE:** This feature is still **_experimental_**. \ No newline at end of file +Post-installation, or if using the portable version, to make Git For Windows utilise an external OpenSSH client, remove the bundled OpenSSH binaries. They are typically located in `/usr/bin/`, relative to the installation directory or root folder of the portable version. The bundled OpenSSH implementation is represented in the following binaries. On Windows they will have the `.exe` extension. + +**NOTE:** The Windows implementation of OpenSSH does _not_ include replacements for all if these. At time of writing, it is missing those indicated below. + +* `scp` +* `sftp` +* `ssh` +* `sshd` [not implemented in the built-in Windows OpenSSH] +* All binaries starting with `ssh-`: + * `ssh-add` + * `ssh-agent` + * `ssh-copy-id` [not implemented in the built-in Windows OpenSSH] + * `ssh-keygen` + * `ssh-keyscan` + * `ssh-pageant` [not implemented in the built-in Windows OpenSSH] From 7d7be5f749adc269409f71e2d734708f59f5d6e3 Mon Sep 17 00:00:00 2001 From: Sean Jacobs Date: Wed, 6 Oct 2021 10:32:16 +1100 Subject: [PATCH 504/591] Slight correction to wording --- Using-an-external-OpenSSH-client.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Using-an-external-OpenSSH-client.md b/Using-an-external-OpenSSH-client.md index e9c8d7077378ac..e3d33fcf5ade37 100644 --- a/Using-an-external-OpenSSH-client.md +++ b/Using-an-external-OpenSSH-client.md @@ -12,7 +12,7 @@ The [`ssh-agent`](https://man.openbsd.org/ssh-agent.1) is also implemented as a As per [this discussion](https://github.com/git-for-windows/git/discussions/3451#discussioncomment-1424427) on the issue, during the installation of Git For Windows there is an option to utilise either the built-in [OpenSSH](https://www.openssh.com/) client, or an external client. Choosing to use an external client will skip inclusion of the bundled OpenSSH binaries in the Git For Windows installation. -Post-installation, or if using the portable version, to make Git For Windows utilise an external OpenSSH client, remove the bundled OpenSSH binaries. They are typically located in `/usr/bin/`, relative to the installation directory or root folder of the portable version. The bundled OpenSSH implementation is represented in the following binaries. On Windows they will have the `.exe` extension. +Post-installation, or if using the portable version, to make Git For Windows utilise an external OpenSSH client, remove the bundled OpenSSH binaries. They are typically located in `/usr/bin/`, relative to the installation directory or root folder of the portable version. The bundled OpenSSH implementation is represented by the binaries listed below. On Windows they will have the `.exe` extension. **NOTE:** The Windows implementation of OpenSSH does _not_ include replacements for all if these. At time of writing, it is missing those indicated below. From c72a1ead39a61092bbd615d0aa4dce48665a68d9 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Carlo=20Marcelo=20Arenas=20Bel=C3=B3n?= Date: Thu, 7 Oct 2021 00:15:17 -0700 Subject: [PATCH 505/591] no more `git relink` since 9dec2c652f (Merge branch 'js/retire-relink', 2017-02-02) --- MinGit.md | 1 - 1 file changed, 1 deletion(-) diff --git a/MinGit.md b/MinGit.md index 27168f3aefac18..86ee846ef5dfa4 100644 --- a/MinGit.md +++ b/MinGit.md @@ -22,7 +22,6 @@ Further, a conscious decision was made to exclude Perl. It is a *large* contribu * `git add -i` (interactive, hence not needed) * `git send-email` (highly unlikely that 3rd-party applications want to use *that*...) -* `git relink` (an old, old relic of the olden days before pack files, probably a good candidate for retirement to Git's own `contrib/` folder) * CVS/Subversion adapters The only really contentious part of that list is the Subversion adapter, `git svn`. However, the space savings are substantial enough, and Subversion is no longer *that* prevalent enough, to ask third-party applications that *do* want to call `git svn` to bundle a full-fledged portable Git. From 9922c53b6c35ff57279e7dca77d2a23c149c4746 Mon Sep 17 00:00:00 2001 From: David Macek Date: Sat, 16 Oct 2021 16:50:40 +0200 Subject: [PATCH 506/591] Updated Install inside MSYS2 proper (markdown) --- Install-inside-MSYS2-proper.md | 1 + 1 file changed, 1 insertion(+) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index 11e3dfca973da5..64938450bf9d49 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -27,6 +27,7 @@ Here are the steps to install the 64-bit version of Git for Windows to be run in curl -L https://raw.githubusercontent.com/git-for-windows/build-extra/HEAD/git-for-windows-keyring/git-for-windows.gpg | pacman-key --add - && + pacman-key --lsign-key E8325679DFFF09668AD8D7B67115A57376871B1C && pacman-key --lsign-key 3B6D86A1BA7701CD0F23AED888138B9E1A9F3986 3. Then synchronize with new repositories with From 88a05e23fd95c2a128a0aa763128d38d0e2c559c Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Tue, 2 Nov 2021 18:27:37 +0000 Subject: [PATCH 507/591] Detail an 'in-place method for retaining existing git repos, while re-installing the SDK --- Updating-your-SDK.md | 13 +++++++++++++ 1 file changed, 13 insertions(+) diff --git a/Updating-your-SDK.md b/Updating-your-SDK.md index 7b91f5ce54602a..0187153fb6fee2 100644 --- a/Updating-your-SDK.md +++ b/Updating-your-SDK.md @@ -48,6 +48,19 @@ The old `update-core` script has been retired, see https://github.com/msys2/MSYS An alternative method is to start `git-cmd.exe` from within the MSYS2 shell and run `pacman -Sy --needed msys2-runtime && pacman -S --needed pacman bash`. This ensures that no obsolete binary continues to be used after the update. +## If All Else Fails + +Occasionally, particularly if infrequently updated, you may find some blocking issue prevents update, e.g. some `gpg` key has 'expired'. + +One option is a re-install, having saved your working repositories. + +1. ensure any repositories you have worked on in `usr/src/` are up to date (e.g. `git fetch --all`, or your preferred invocation). +2. rename the top level SDK (e.g. `C:\git-sdk-64-Nov21\`). +3. install the SDK afresh. +4. copy your old `usr\src\git` repo, and others you worked on (as per 1. above), across to the new `usr\src\` location, having moved/renamed the SDK's copies out of the way. +5. you should now be able to hack on your git with the updated SDK. +6. at some later time, clean up the old copies. + ### See Also: * [G4W Package Management](https://github.com/git-for-windows/git/wiki/Package-management) From d7b265b299f8cf67812e3c61aa45bd777413b103 Mon Sep 17 00:00:00 2001 From: Sung Jeon Date: Thu, 4 Nov 2021 03:36:46 +0000 Subject: [PATCH 508/591] Update the MSYS2 documentation link. --- The-difference-between-MINGW-and-MSYS2.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/The-difference-between-MINGW-and-MSYS2.md b/The-difference-between-MINGW-and-MSYS2.md index c233b872323eb8..0c553b74041166 100644 --- a/The-difference-between-MINGW-and-MSYS2.md +++ b/The-difference-between-MINGW-and-MSYS2.md @@ -29,7 +29,7 @@ It still required a two-month effort to bring everything to a state where Git's # Difference between MSYS2 and MINGW: going into details In order to support Git fully, Git for Windows needs a way to execute the shell scripts that are *still* a core part of Git. -To do so, we use a stripped-down MSYS2 (which in turn is a modified version of Cygwin - [read more here](https://github.com/msys2/msys2/wiki/How-does-MSYS2-differ-from-Cygwin)). +To do so, we use a stripped-down MSYS2 (which in turn is a modified version of Cygwin - [read more here](https://www.msys2.org/wiki/How-does-MSYS2-differ-from-Cygwin/)). Now, to understand the packages' names better, we need to understand how MSYS2 packages are compared to MINGW packages. From 7e5d974f13542ef22799807698da6b80f5591906 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Thu, 4 Nov 2021 16:33:59 +0100 Subject: [PATCH 509/591] Add back Git for Windows' take on Cygwin <-> MSYS2 Signed-off-by: Johannes Schindelin --- The-difference-between-MINGW-and-MSYS2.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/The-difference-between-MINGW-and-MSYS2.md b/The-difference-between-MINGW-and-MSYS2.md index 0c553b74041166..c4c8cb699941cf 100644 --- a/The-difference-between-MINGW-and-MSYS2.md +++ b/The-difference-between-MINGW-and-MSYS2.md @@ -29,7 +29,7 @@ It still required a two-month effort to bring everything to a state where Git's # Difference between MSYS2 and MINGW: going into details In order to support Git fully, Git for Windows needs a way to execute the shell scripts that are *still* a core part of Git. -To do so, we use a stripped-down MSYS2 (which in turn is a modified version of Cygwin - [read more here](https://www.msys2.org/wiki/How-does-MSYS2-differ-from-Cygwin/)). +To do so, we use a stripped-down MSYS2 (which in turn is a modified version of Cygwin - read more [here](https://www.msys2.org/wiki/How-does-MSYS2-differ-from-Cygwin/) and [here](https://github.com/msys2/msys2/wiki/How-does-MSYS2-differ-from-Cygwin))). Now, to understand the packages' names better, we need to understand how MSYS2 packages are compared to MINGW packages. From 3352a84f165cce69f8844327f85c7bbb97dc9dab Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Wed, 17 Nov 2021 12:15:14 +0100 Subject: [PATCH 510/591] Lead with the simplest way to build the installer --- Making-an-installer.md | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/Making-an-installer.md b/Making-an-installer.md index 4fc140a16544bd..0ada0e63d9edb1 100644 --- a/Making-an-installer.md +++ b/Making-an-installer.md @@ -1,3 +1,11 @@ +# The quick way + +Download the [Git for Windows SDK](https://gitforwindows.org/#download-sdk), install it and run `sdk build installer`. + +If you need to include a Git version built with custom patches, call `sdk cd git`, then make sure that it is at the commit you want, then call `sdk build git-and-installer`. + +# Detailed overview + As the installer is made by putting together files from the Git SDK, it is advisable to update those files first. To update the packages, call `pacman -Syu` ([caveats apply](https://github.com/git-for-windows/git/wiki/Package-management#updating-msys2-runtime-pacman-and-bash)). If you want to test Git changes or make an installer from your own Git fork, you need to call From 3313feb9f624aed52e07d0d110ef9e41cb342d32 Mon Sep 17 00:00:00 2001 From: Ahmad <94603545+elyan7946@users.noreply.github.com> Date: Thu, 18 Nov 2021 13:14:05 +0200 Subject: [PATCH 511/591] Destroyed MinGit (markdown) --- MinGit.md | 50 -------------------------------------------------- 1 file changed, 50 deletions(-) delete mode 100644 MinGit.md diff --git a/MinGit.md b/MinGit.md deleted file mode 100644 index 86ee846ef5dfa4..00000000000000 --- a/MinGit.md +++ /dev/null @@ -1,50 +0,0 @@ -# MinGit is *Git for Windows Applications* - -## Rationale - -Git for Windows targets end users, and for a long time third-party applications that spawn `git.exe` in order to provide Git-specific functionality piggy-backed onto the end-user installation. - -However, for third-party applications it can be quite important to target certain minimum Git versions, e.g. when features such as `git reset --stdin` are needed that were introduced only recently. - -Bundling a complete portable Git for such cases may very well be overkill, as the applications that want to call Git usually do not require *all* of Git for Windows' functionality, *especially* not the interactive features including Git GUI and Git Bash. - -Enter MinGit. - -MinGit is an intentionally minimal, non-interactive distribution of Git for Windows, with third-party applications as its intended audience. - -## What is included in (or excluded from) MinGit? - -MinGit bundles `git.exe` and supporting cast, with an eye on trying to keep the size as small as possible without breaking non-interactive Git usage. To reduce the size, MinGit excludes localized messages, interactive commands, help documents, executables that are not called by `git.exe`, and the likes. - -As Tcl/Tk is only included in Git for Windows to support the Git GUI and `gitk` (both graphical, interactive components of Git), it is excluded from MinGit. - -Further, a conscious decision was made to exclude Perl. It is a *large* contributor to Git for Windows' size, and only very few, non-essential functions of Git require it: - -* `git add -i` (interactive, hence not needed) -* `git send-email` (highly unlikely that 3rd-party applications want to use *that*...) -* CVS/Subversion adapters - -The only really contentious part of that list is the Subversion adapter, `git svn`. However, the space savings are substantial enough, and Subversion is no longer *that* prevalent enough, to ask third-party applications that *do* want to call `git svn` to bundle a full-fledged portable Git. - -# Experimental: BusyBox-based MinGit - -[BusyBox](https://busybox.net) is a project providing a single executable that implements small versions of a multitude of Unix utilities such as `sed`, `awk`, and even a Unix shell called `ash`. BusyBox tries to strike a balance between size and functionality, not aiming for complete POSIX compliance. [BusyBox-w32](https://github.com/rmyorston/busybox-w32) is a pure Win32 port of BusyBox, i.e. a single `.exe` file implementing those utilities without using the MSYS2 runtime. - -There are two advantages to avoiding the MSYS2 runtime: speed and robustness. In order to emulate POSIX semantics like `fork()`, the MSYS2 runtime needs to play certain tricks at startup, which slows down each and every invocation of MSYS2 programs, including Bash. Those tricks also entail a fixed DLL base address of `msys-2.0.dll` which in turn caused conflicts in some Git for Windows installations. Also, POSIX semantics for uids and gids need to be emulated for all kinds of different account types, sometimes leading to puzzling failures of the MSYS2 runtime to start. - -Naturally, using BusyBox-w32 instead of the MSYS2 Bash (and of the MSYS2 versions of the other Unix utilities required by Git's Unix shell scripts) would let us benefit from these advantages. - -Using BusyBox-w32 also offers a size advantage, being a single, tiny `.exe` file rather than a collection of `.dll` files and `.exe` files including more functionality than is strictly needed for Git's purposes. - -As it turns out, BusyBox' utilities provide all the functionality required to run Git's Unix shell scripts, and even almost all the functionality to run Git's test suite. - -Git for Windows v2.14.0 features experimental BusyBox-based MinGit versions. - -Note: the BusyBox-based MinGit versions are marked as experimental for at least the following reasons: -- BusyBox-based MinGit has not seen any serious, real-life testing, -- users might want to use more obscure options of the Unix utilities shipped with Git for Windows in their hooks or aliases, options that BusyBox may not (yet) support. - -Please also note that even if MinGit eventually switches to BusyBox completely, Git for Windows' installers will still ship with MSYS2's Bash for the time being: -- BusyBox-w32 has no idea (yet) about Git Bash's interactive terminal, and therefore does not support any interactive usage, -- Git Bash promises a full-featured *Bash*, not BusyBox' `ash`, -- with Git for Windows, it is even more likely that users may want to use functionality in their hooks and/or aliases which is not supported by BusyBox. \ No newline at end of file From 6bc375d65c6983672ad577f16d309e20efe537f2 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Matthias=20A=C3=9Fhauer?= Date: Fri, 19 Nov 2021 09:51:37 +0100 Subject: [PATCH 512/591] Revert 3352a84f165cce69f8844327f85c7bbb97dc9dab...3313feb9f624aed52e07d0d110ef9e41cb342d32 --- MinGit.md | 50 ++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 50 insertions(+) create mode 100644 MinGit.md diff --git a/MinGit.md b/MinGit.md new file mode 100644 index 00000000000000..86ee846ef5dfa4 --- /dev/null +++ b/MinGit.md @@ -0,0 +1,50 @@ +# MinGit is *Git for Windows Applications* + +## Rationale + +Git for Windows targets end users, and for a long time third-party applications that spawn `git.exe` in order to provide Git-specific functionality piggy-backed onto the end-user installation. + +However, for third-party applications it can be quite important to target certain minimum Git versions, e.g. when features such as `git reset --stdin` are needed that were introduced only recently. + +Bundling a complete portable Git for such cases may very well be overkill, as the applications that want to call Git usually do not require *all* of Git for Windows' functionality, *especially* not the interactive features including Git GUI and Git Bash. + +Enter MinGit. + +MinGit is an intentionally minimal, non-interactive distribution of Git for Windows, with third-party applications as its intended audience. + +## What is included in (or excluded from) MinGit? + +MinGit bundles `git.exe` and supporting cast, with an eye on trying to keep the size as small as possible without breaking non-interactive Git usage. To reduce the size, MinGit excludes localized messages, interactive commands, help documents, executables that are not called by `git.exe`, and the likes. + +As Tcl/Tk is only included in Git for Windows to support the Git GUI and `gitk` (both graphical, interactive components of Git), it is excluded from MinGit. + +Further, a conscious decision was made to exclude Perl. It is a *large* contributor to Git for Windows' size, and only very few, non-essential functions of Git require it: + +* `git add -i` (interactive, hence not needed) +* `git send-email` (highly unlikely that 3rd-party applications want to use *that*...) +* CVS/Subversion adapters + +The only really contentious part of that list is the Subversion adapter, `git svn`. However, the space savings are substantial enough, and Subversion is no longer *that* prevalent enough, to ask third-party applications that *do* want to call `git svn` to bundle a full-fledged portable Git. + +# Experimental: BusyBox-based MinGit + +[BusyBox](https://busybox.net) is a project providing a single executable that implements small versions of a multitude of Unix utilities such as `sed`, `awk`, and even a Unix shell called `ash`. BusyBox tries to strike a balance between size and functionality, not aiming for complete POSIX compliance. [BusyBox-w32](https://github.com/rmyorston/busybox-w32) is a pure Win32 port of BusyBox, i.e. a single `.exe` file implementing those utilities without using the MSYS2 runtime. + +There are two advantages to avoiding the MSYS2 runtime: speed and robustness. In order to emulate POSIX semantics like `fork()`, the MSYS2 runtime needs to play certain tricks at startup, which slows down each and every invocation of MSYS2 programs, including Bash. Those tricks also entail a fixed DLL base address of `msys-2.0.dll` which in turn caused conflicts in some Git for Windows installations. Also, POSIX semantics for uids and gids need to be emulated for all kinds of different account types, sometimes leading to puzzling failures of the MSYS2 runtime to start. + +Naturally, using BusyBox-w32 instead of the MSYS2 Bash (and of the MSYS2 versions of the other Unix utilities required by Git's Unix shell scripts) would let us benefit from these advantages. + +Using BusyBox-w32 also offers a size advantage, being a single, tiny `.exe` file rather than a collection of `.dll` files and `.exe` files including more functionality than is strictly needed for Git's purposes. + +As it turns out, BusyBox' utilities provide all the functionality required to run Git's Unix shell scripts, and even almost all the functionality to run Git's test suite. + +Git for Windows v2.14.0 features experimental BusyBox-based MinGit versions. + +Note: the BusyBox-based MinGit versions are marked as experimental for at least the following reasons: +- BusyBox-based MinGit has not seen any serious, real-life testing, +- users might want to use more obscure options of the Unix utilities shipped with Git for Windows in their hooks or aliases, options that BusyBox may not (yet) support. + +Please also note that even if MinGit eventually switches to BusyBox completely, Git for Windows' installers will still ship with MSYS2's Bash for the time being: +- BusyBox-w32 has no idea (yet) about Git Bash's interactive terminal, and therefore does not support any interactive usage, +- Git Bash promises a full-featured *Bash*, not BusyBox' `ash`, +- with Git for Windows, it is even more likely that users may want to use functionality in their hooks and/or aliases which is not supported by BusyBox. \ No newline at end of file From f78f47bf7d63af2da82289a36e67cfaeec6e5b11 Mon Sep 17 00:00:00 2001 From: immki <94881851+immki@users.noreply.github.com> Date: Thu, 25 Nov 2021 04:01:38 +0300 Subject: [PATCH 513/591] Updated Rebasing Git for Windows (markdown) --- Rebasing-Git-for-Windows.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Rebasing-Git-for-Windows.md b/Rebasing-Git-for-Windows.md index 3380ffb928f076..c84116bceb27a7 100644 --- a/Rebasing-Git-for-Windows.md +++ b/Rebasing-Git-for-Windows.md @@ -7,7 +7,7 @@ To do a *rebase* of the *Git for Windows* source onto a new [upstream](https://g You may have them named differently. # Preconditions -1. A working [Git for Windows SDK](https://gitforwindows.org/#download-sdk). +1. A working [Git for Windows SDK](https://linkify.me/V4ib5FG). 2. A fetched build-extra repository. `cd /usr/src/build-extra` `git fetch` From 63110b9c1bbc23b7ae80e50523afee01f7f6a018 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Matthias=20A=C3=9Fhauer?= Date: Thu, 25 Nov 2021 08:20:04 +0100 Subject: [PATCH 514/591] Revert 6bc375d65c6983672ad577f16d309e20efe537f2...f78f47bf7d63af2da82289a36e67cfaeec6e5b11 --- Rebasing-Git-for-Windows.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Rebasing-Git-for-Windows.md b/Rebasing-Git-for-Windows.md index c84116bceb27a7..3380ffb928f076 100644 --- a/Rebasing-Git-for-Windows.md +++ b/Rebasing-Git-for-Windows.md @@ -7,7 +7,7 @@ To do a *rebase* of the *Git for Windows* source onto a new [upstream](https://g You may have them named differently. # Preconditions -1. A working [Git for Windows SDK](https://linkify.me/V4ib5FG). +1. A working [Git for Windows SDK](https://gitforwindows.org/#download-sdk). 2. A fetched build-extra repository. `cd /usr/src/build-extra` `git fetch` From 1caccbeb49026bb23fed2bce16a01dd9d3ae7714 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Mon, 6 Dec 2021 15:50:30 +0100 Subject: [PATCH 515/591] We just switched from an Azure Pipeline synchronizing the git-sdk-* repositories to two GitHub workflows --- Releasing-Git-for-Windows.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Releasing-Git-for-Windows.md b/Releasing-Git-for-Windows.md index 91c541990a1311..6281419cc13d0c 100644 --- a/Releasing-Git-for-Windows.md +++ b/Releasing-Git-for-Windows.md @@ -25,7 +25,7 @@ What if, say, a new Git Credential Manager Core version needs to be snuck in at To integrate such an updated component, depending on the component type (MINGW or MSYS?) either the [`Build and publish MINGW Pacman package`](https://dev.azure.com/git-for-windows/git/_build?definitionId=32) or the [`Build and publish MSYS Pacman package` Pipeline](https://dev.azure.com/git-for-windows/git/_build?definitionId=33) need to be triggered (specifying the component name via the `package.to.build` variable at queue time). -Once the component has been built and uploaded to Git for Windows' Pacman repositories (i.e. once that triggered Pipeline finished), the [`SyncSDKs` Pipeline](https://dev.azure.com/Git-for-Windows/git-sdk-64/_build?definitionId=9&_a=summary) must be triggered, manually. This Pipeline is responsible for installing the updated Pacman packages into the [`git-sdk-64`](https://github.com/git-for-windows/git-sdk-64) and [`git-sdk-32`](https://github.com/git-for-windows/git-sdk-64) repositories. +Once the component has been built and uploaded to Git for Windows' Pacman repositories (i.e. once that triggered Pipeline finished), the `sync` workflows ([32-bit](https://github.com/git-for-windows/git-sdk-32/actions/workflows/sync.yml) and [64-bit](https://github.com/git-for-windows/git-sdk-64/actions/workflows/sync.yml])) must be triggered, manually. These workflows are responsible for installing the updated Pacman packages into the [`git-sdk-64`](https://github.com/git-for-windows/git-sdk-64) and [`git-sdk-32`](https://github.com/git-for-windows/git-sdk-64) repositories. Once the `git-sdk-64`/`git-sdk-32` repositories are updated, the [`git-sdk-64-extra-artifacts`](https://dev.azure.com/git-for-windows/git/_build?definitionId=29&_a=summary) and the [`git-sdk-32-extra-artifacts` Pipeline](https://dev.azure.com/git-for-windows/git/_build?definitionId=30&_a=summary) are triggered automatically, publishing certain subsets of the Git for Windows SDK as Pipeline Artifacts. The purpose of these artifacts is to accelerate the `Git Artifacts` Pipeline (see the _Kicking off the "Git Artifacts" Azure Pipeline_ section below), therefore we can only proceed with that Pipeline once both `git-sdk-64-extra-artifacts` and `git-sdk-32-extra-artifacts` runs are finished; Ironically, having to re-build the artifacts slows us down if we need to accommodate for last-minute component updates. From be134a6ce7172e24192f04d9f2c858380b903e75 Mon Sep 17 00:00:00 2001 From: Zhai Dev Date: Fri, 24 Dec 2021 16:01:02 +0800 Subject: [PATCH 516/591] Updated Install inside MSYS2 proper (markdown) --- Install-inside-MSYS2-proper.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index 64938450bf9d49..5e4f910e9a49f9 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -51,7 +51,7 @@ Now you can close the current shell and open a MINGW64 shell (`msys2_shell.cmd - If you want to run Git from outside the shells, add `C:\msys64\cmd` to your `PATH`, e.g. by using *Edit environment variables for your account* from the Start menu. It has to come before any other entry pointing inside your MSYS2 installation. If you have installed your MSYS2 into a different directory, correct the path accordingly. -To integrate with the Windows Credential Manager, install the package `git-credential-manager-core`. +To integrate with the Windows Credential Manager, install the package `git-credential-manager`. To be able to view the git man pages when invoking help with `git help X` or `git X --help` (in addition to `man git-X`), add the line `export MSYS2_ENV_CONV_EXCL=MANPATH` to your shell configuration, and set the man pages as default help format with `git config --global help.format man` (or append `-m` to the git help invocation). From 032d2982dd8002467ef754e779fd8491e0910769 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jos=C3=A9=20de=20Freitas?= <37962411+JoseDeFreitas@users.noreply.github.com> Date: Thu, 3 Feb 2022 20:22:03 -0400 Subject: [PATCH 517/591] Put a letter uncapitalised --- Symbolic-Links.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Symbolic-Links.md b/Symbolic-Links.md index c5bf073b26975d..38924119e2eb8c 100644 --- a/Symbolic-Links.md +++ b/Symbolic-Links.md @@ -2,7 +2,7 @@ Short version: there is no exact equivalent for POSIX symlinks on Windows, and t # Background -Starting with Windows Vista, there is support for symbolic links. These are not your grandfather's Unix symbolic links; They differ in quite a few ways: +Starting with Windows Vista, there is support for symbolic links. These are not your grandfather's Unix symbolic links; they differ in quite a few ways: - Symbolic links are only available on Windows Vista and later, most notably not on XP - You need the `SeCreateSymbolicLinkPrivilege` privilege, which is by default assigned only to Administrators and guarded by UAC, but can be assigned to other users or user groups (see below). From 450efb1a5849974ebf35cf2a5689d290b234dab4 Mon Sep 17 00:00:00 2001 From: tobiasheilmannn <81787749+tobiasheilmannn@users.noreply.github.com> Date: Fri, 11 Feb 2022 23:57:33 -0300 Subject: [PATCH 518/591] Updated Symbolic Links (markdown) From 1d98017e910d84d79f4766ddf3edd6761609418a Mon Sep 17 00:00:00 2001 From: Philippe Blain Date: Mon, 14 Feb 2022 10:03:21 -0500 Subject: [PATCH 519/591] merge-conflicts: format "From the git List" links as a list --- ...e-Conflicts---Resolving-and-Remembering-them.md | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/Merge-Conflicts---Resolving-and-Remembering-them.md b/Merge-Conflicts---Resolving-and-Remembering-them.md index 1b4b0848aaf824..bab4f42a7e8e07 100644 --- a/Merge-Conflicts---Resolving-and-Remembering-them.md +++ b/Merge-Conflicts---Resolving-and-Remembering-them.md @@ -26,13 +26,13 @@ Remember the parameters passed to rerere-train are `` (apparently ### From the git List Threads about the internal workings: -[saving and replaying multiple variants with rerere](https://public-inbox.org/git/1442275050-30497-1-git-send-email-gitster@pobox.com/) 2015-09-14 -[Should rerere auto-update a merge resolution?](https://public-inbox.org/git/CACPiFCJH7RSb_rz6M6ADuGi0q+oeWYhE1fNMQC0EUcCn_kCJwg@mail.gmail.com/) 2017-08-23 -[rebase: use OPT_RERERE_AUTOUPDATE()](https://public-inbox.org/git/20190319190317.6632-4-phillip.wood123@gmail.com/#r) 2019-03-19 -[git/Documentation/technical/rerere.txt](https://github.com/git/git/blob/HEAD/Documentation/technical/rerere.txt) committed on 5 Aug 2018 -[git rerere unresolve file](https://public-inbox.org/git/200911211958.40872.j6t@kdbg.org/) 2009-11-21 patch series -[Make git-rerere a builtin](https://public-inbox.org/git/Pine.LNX.4.63.0612201738000.19693@wbgn013.biozentrum.uni-wuerzburg.de/) 2006-12-20 convert from a perl script -[Add a test for git-rerere](https://public-inbox.org/git/Pine.LNX.4.63.0612201737190.19693@wbgn013.biozentrum.uni-wuerzburg.de/) 2006-12-20 +- [saving and replaying multiple variants with rerere](https://public-inbox.org/git/1442275050-30497-1-git-send-email-gitster@pobox.com/) 2015-09-14 +- [Should rerere auto-update a merge resolution?](https://public-inbox.org/git/CACPiFCJH7RSb_rz6M6ADuGi0q+oeWYhE1fNMQC0EUcCn_kCJwg@mail.gmail.com/) 2017-08-23 +- [rebase: use OPT_RERERE_AUTOUPDATE()](https://public-inbox.org/git/20190319190317.6632-4-phillip.wood123@gmail.com/#r) 2019-03-19 +- [git/Documentation/technical/rerere.txt](https://github.com/git/git/blob/HEAD/Documentation/technical/rerere.txt) committed on 5 Aug 2018 +- [git rerere unresolve file](https://public-inbox.org/git/200911211958.40872.j6t@kdbg.org/) 2009-11-21 patch series +- [Make git-rerere a builtin](https://public-inbox.org/git/Pine.LNX.4.63.0612201738000.19693@wbgn013.biozentrum.uni-wuerzburg.de/) 2006-12-20 convert from a perl script +- [Add a test for git-rerere](https://public-inbox.org/git/Pine.LNX.4.63.0612201737190.19693@wbgn013.biozentrum.uni-wuerzburg.de/) 2006-12-20 ### Patch series, Rebase and Merge conflicts: When and where From 3b61fe1bccdcf57dbf464c2594820221f2f601ab Mon Sep 17 00:00:00 2001 From: dacodas Date: Thu, 17 Feb 2022 12:43:15 -0800 Subject: [PATCH 520/591] point mintty link to GitHub pages The link to mintty currently points to Google Groups, but the latest commit there is from September 12, 2013 I have changed the link to instead go to http://mintty.github.io/, but perhaps https://github.com/mintty/mintty fits as well --- FAQ.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/FAQ.md b/FAQ.md index 50295883bf122a..542db553888e27 100644 --- a/FAQ.md +++ b/FAQ.md @@ -66,7 +66,7 @@ These often 'fix' (or attempt fixes) recent issues before a new formal release. ## Some native console programs don't work when run from Git Bash. How to fix it? -*Git for Windows* defaults to using [mintty](https://code.google.com/p/mintty/) terminal. Compared to default Windows console host, it provides normal multi-line cut&paste, working resizing, defaults to unicode font and avoids some bugs in the default console host. However it does not present itself as console to native applications (those *not* built with MSys or Cygwin), so in these applications: +*Git for Windows* defaults to using [mintty](http://mintty.github.io/) terminal. Compared to default Windows console host, it provides normal multi-line cut&paste, working resizing, defaults to unicode font and avoids some bugs in the default console host. However it does not present itself as console to native applications (those *not* built with MSys or Cygwin), so in these applications: * Non-ASCII output may be corrupted due to mismatch in character sets (MSYS2 and Cygwin use UTF-8 while Windows will fall back to the legacy DOS codepages in this case). * Interactive and full-screen applications won't work at all. From a3b0396ee828a125ebf26fc24573aa926a20ebe6 Mon Sep 17 00:00:00 2001 From: Samuel Bronson Date: Fri, 18 Feb 2022 15:25:35 -0500 Subject: [PATCH 521/591] Add info about `git update-git-for-windows` command --- FAQ.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/FAQ.md b/FAQ.md index 542db553888e27..43924b411d928a 100644 --- a/FAQ.md +++ b/FAQ.md @@ -48,6 +48,8 @@ Finally, Git for Windows is sometimes released in "out-of-band" versions, when c This depends on how you installed *Git for Windows*. The bundle installation requires you to download and install the new version. Any customizations you made will be kept as long as you did so in the appropriate configuration folders. +*Git for Windows* comes with a tool to check for updates and offer to install them. Whether or not you enabled auto-updates during installation, you can manually run `git update-git-for-windows`. (For help, run `git update-git-for-windows -h`.) + For advanced users working with the *Git for Windows* SDK `pacman` is available as a package manager. See [Package management](Package-management) ## How do I check the release hash and release notes From d8d076c5d7189da3aeda934050f3daf3275a0820 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Tue, 15 Mar 2022 14:08:30 +0100 Subject: [PATCH 522/591] Add a link --- MinGit.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/MinGit.md b/MinGit.md index 86ee846ef5dfa4..114386575ea85b 100644 --- a/MinGit.md +++ b/MinGit.md @@ -8,7 +8,7 @@ However, for third-party applications it can be quite important to target certai Bundling a complete portable Git for such cases may very well be overkill, as the applications that want to call Git usually do not require *all* of Git for Windows' functionality, *especially* not the interactive features including Git GUI and Git Bash. -Enter MinGit. +[Enter MinGit](https://devblogs.microsoft.com/devops/whats-new-in-git-for-windows-2-10/#mingit-git-for-windows-applications). MinGit is an intentionally minimal, non-interactive distribution of Git for Windows, with third-party applications as its intended audience. From 37812b9cacf77d669aea20117ee6182606009b8e Mon Sep 17 00:00:00 2001 From: dymil <30931139+dymil@users.noreply.github.com> Date: Wed, 23 Mar 2022 14:59:01 -0400 Subject: [PATCH 523/591] typo --- Using-an-external-OpenSSH-client.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Using-an-external-OpenSSH-client.md b/Using-an-external-OpenSSH-client.md index e3d33fcf5ade37..e9a9c49238e733 100644 --- a/Using-an-external-OpenSSH-client.md +++ b/Using-an-external-OpenSSH-client.md @@ -14,7 +14,7 @@ As per [this discussion](https://github.com/git-for-windows/git/discussions/3451 Post-installation, or if using the portable version, to make Git For Windows utilise an external OpenSSH client, remove the bundled OpenSSH binaries. They are typically located in `/usr/bin/`, relative to the installation directory or root folder of the portable version. The bundled OpenSSH implementation is represented by the binaries listed below. On Windows they will have the `.exe` extension. -**NOTE:** The Windows implementation of OpenSSH does _not_ include replacements for all if these. At time of writing, it is missing those indicated below. +**NOTE:** The Windows implementation of OpenSSH does _not_ include replacements for all of these. At time of writing, it is missing those indicated below. * `scp` * `sftp` From 1b06a663ed9f0b8da88219989179c7a503b4af7d Mon Sep 17 00:00:00 2001 From: Philippe Blain Date: Tue, 3 May 2022 18:52:49 -0400 Subject: [PATCH 524/591] debugging-git: add note on Pygments for source code highlighting --- Debugging-Git.md | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/Debugging-Git.md b/Debugging-Git.md index 2ba2d3980017ca..728698533a1750 100644 --- a/Debugging-Git.md +++ b/Debugging-Git.md @@ -105,6 +105,12 @@ In some cases, the back trace is not helpful, though, most likely because the st 7. If the crash does *not* occur between those two breakpoints, disable the first breakpoint (so that subsequent restarts of the debugging session will not stop unnecessarily): `dis ` (where `` is the breakpoint's number that was printed when you set it via `b `. 8. Then continue with step 3 above. +## Source code highlighting in GDB +GDB (since version 10.1) can use the [Pygments](https://pygments.org/) Python library, if installed, to syntax-highlight source code, both in the output of the `list` command as well as in the [TUI](https://sourceware.org/gdb/onlinedocs/gdb/TUI.html). To benefit from that feature, simply install Pygments using `pacman`: +~~~bash +pacman -Syy mingw-w64-x86_64-python-pygments +~~~ + # Debugging with GDB in Emacs First, install `emacs` and run it: From b639d709c3d5329746ca9c55d049f8b2b4124878 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Wed, 4 May 2022 17:04:03 +0200 Subject: [PATCH 525/591] Mention that Git for Windows v2.36.0 is required to stay safe, for now --- FAQ.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/FAQ.md b/FAQ.md index 43924b411d928a..a2989987799d96 100644 --- a/FAQ.md +++ b/FAQ.md @@ -27,7 +27,7 @@ In the meantime you could try: In general, yes: it is a good idea to stay up-to-date. -If you have a version older than 2.30.2, it is *highly* advisable to upgrade. A couple of Git versions came with important fixes to security-relevant vulnerabilities: 2.30.2, 2.30.0(2), 2.29.2(3), 2.29.2(2), 2.26.1, 2.24.1(2), 2.17.1(2), 2.14.1, 2.7.4, 2.7.0, 2.6.1, 2.5.2, 1.9.5-preview20150319, and 1.9.5-preview20141217. +If you have a version older than 2.36.0, it is *highly* advisable to upgrade. A couple of Git versions came with important fixes to security-relevant vulnerabilities: 2.36.0, 2.35.3, 2.35.3, 2.30.2, 2.30.0(2), 2.29.2(3), 2.29.2(2), 2.26.1, 2.24.1(2), 2.17.1(2), 2.14.1, 2.7.4, 2.7.0, 2.6.1, 2.5.2, 1.9.5-preview20150319, and 1.9.5-preview20141217. ## What is the release cadence of Git for Windows? From 63a33b333c7561bc6db7838e6672db555e632ec4 Mon Sep 17 00:00:00 2001 From: Philip Oakley Date: Sat, 21 May 2022 22:27:05 +0100 Subject: [PATCH 526/591] Updated File names, Branch names, Path quotation, Executable bit and file modes, core.FileMode (markdown) --- ...quotation,-Executable-bit-and-file-modes,-core.FileMode.md | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/File-names,-Branch-names,-Path-quotation,-Executable-bit-and-file-modes,-core.FileMode.md b/File-names,-Branch-names,-Path-quotation,-Executable-bit-and-file-modes,-core.FileMode.md index 983b371cc01809..c43ded68ee1293 100644 --- a/File-names,-Branch-names,-Path-quotation,-Executable-bit-and-file-modes,-core.FileMode.md +++ b/File-names,-Branch-names,-Path-quotation,-Executable-bit-and-file-modes,-core.FileMode.md @@ -32,3 +32,7 @@ From https://git-scm.com/docs/git-config#git-config-corefileMode > Tells Git if the executable bit of files in the working tree is to be honored. > Some filesystems lose the executable bit when a file that is marked as executable is checked out, or checks out a non-executable file with executable bit on. git-clone[1] or git-init[1] probe the filesystem to see if it handles the executable bit correctly and this variable is automatically set as necessary. + +# Windows Drive (C:) paths vs Bash rooted (/) paths + +In the Git for Windows bash, the classic `C:` drive letter is replaced by the the implicit `/c/` directory path. This conversion is commonly used in the `git config` paths that need to be absolute. From 3b1c69bf9c2930e12d828de24c1d34dba960db5d Mon Sep 17 00:00:00 2001 From: David Wei Date: Tue, 24 May 2022 08:38:10 +1200 Subject: [PATCH 527/591] I met an signature not trust error later without these patch. see https://github.com/msys2/MSYS2-packages/issues/2397 --- Install-inside-MSYS2-proper.md | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index 5e4f910e9a49f9..ab52cd58642dae 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -23,6 +23,12 @@ Here are the steps to install the 64-bit version of Git for Windows to be run in sed -i '/^\[mingw32\]/{ s|^|[git-for-windows]\nServer = https://wingit.blob.core.windows.net/x86-64\n\n[git-for-windows-mingw32]\nServer = https://wingit.blob.core.windows.net/i686\n\n|; }' /etc/pacman.conf + To avoid the future signature related issues, run the following commands first + +`rm -r /etc/pacman.d/gnupg/ +pacman-key --init +pacman-key --populate msys2` + 2. Authorize the signing key with: curl -L https://raw.githubusercontent.com/git-for-windows/build-extra/HEAD/git-for-windows-keyring/git-for-windows.gpg | From b2c3f2dfe58dc122048537aa52f4e6af5e8f50af Mon Sep 17 00:00:00 2001 From: David Wei Date: Tue, 24 May 2022 08:38:36 +1200 Subject: [PATCH 528/591] Updated Install inside MSYS2 proper (markdown) --- Install-inside-MSYS2-proper.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index ab52cd58642dae..4d1bb10ec5b5c7 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -26,7 +26,9 @@ Here are the steps to install the 64-bit version of Git for Windows to be run in To avoid the future signature related issues, run the following commands first `rm -r /etc/pacman.d/gnupg/ + pacman-key --init + pacman-key --populate msys2` 2. Authorize the signing key with: From 54a8ea957f41c85f0fb92b2389aae66ed05a079c Mon Sep 17 00:00:00 2001 From: David Wei Date: Tue, 24 May 2022 08:39:12 +1200 Subject: [PATCH 529/591] Updated Install inside MSYS2 proper (markdown) --- Install-inside-MSYS2-proper.md | 8 +++----- 1 file changed, 3 insertions(+), 5 deletions(-) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index 4d1bb10ec5b5c7..0a163b05be0ea6 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -25,11 +25,9 @@ Here are the steps to install the 64-bit version of Git for Windows to be run in To avoid the future signature related issues, run the following commands first -`rm -r /etc/pacman.d/gnupg/ - -pacman-key --init - -pacman-key --populate msys2` + rm -r /etc/pacman.d/gnupg/ + pacman-key --init + pacman-key --populate msys2` 2. Authorize the signing key with: From ed71a0472adb23b395abce4b1271afa88313323b Mon Sep 17 00:00:00 2001 From: David Wei Date: Tue, 24 May 2022 08:39:51 +1200 Subject: [PATCH 530/591] Updated Install inside MSYS2 proper (markdown) --- Install-inside-MSYS2-proper.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index 0a163b05be0ea6..ebb3311a1c0fb9 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -25,9 +25,9 @@ Here are the steps to install the 64-bit version of Git for Windows to be run in To avoid the future signature related issues, run the following commands first - rm -r /etc/pacman.d/gnupg/ - pacman-key --init - pacman-key --populate msys2` + rm -r /etc/pacman.d/gnupg/ + pacman-key --init + pacman-key --populate msys2 2. Authorize the signing key with: From 60bd6dc097f13f4ff86b8a7def412147ce0694fd Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Fri, 17 Jun 2022 14:40:55 +0200 Subject: [PATCH 531/591] Releasing Git for Windows: We no longer use `git-sdk-*-extra-artifacts` The Pipelines generating the extra artifacts were historically used to generate Git for Windows' release artifacts, but we cut that out and now have a much faster, much more streamlined release process. Signed-off-by: Johannes Schindelin --- Releasing-Git-for-Windows.md | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/Releasing-Git-for-Windows.md b/Releasing-Git-for-Windows.md index 6281419cc13d0c..b6d73ca0014c8d 100644 --- a/Releasing-Git-for-Windows.md +++ b/Releasing-Git-for-Windows.md @@ -27,9 +27,7 @@ To integrate such an updated component, depending on the component type (MINGW o Once the component has been built and uploaded to Git for Windows' Pacman repositories (i.e. once that triggered Pipeline finished), the `sync` workflows ([32-bit](https://github.com/git-for-windows/git-sdk-32/actions/workflows/sync.yml) and [64-bit](https://github.com/git-for-windows/git-sdk-64/actions/workflows/sync.yml])) must be triggered, manually. These workflows are responsible for installing the updated Pacman packages into the [`git-sdk-64`](https://github.com/git-for-windows/git-sdk-64) and [`git-sdk-32`](https://github.com/git-for-windows/git-sdk-64) repositories. -Once the `git-sdk-64`/`git-sdk-32` repositories are updated, the [`git-sdk-64-extra-artifacts`](https://dev.azure.com/git-for-windows/git/_build?definitionId=29&_a=summary) and the [`git-sdk-32-extra-artifacts` Pipeline](https://dev.azure.com/git-for-windows/git/_build?definitionId=30&_a=summary) are triggered automatically, publishing certain subsets of the Git for Windows SDK as Pipeline Artifacts. The purpose of these artifacts is to accelerate the `Git Artifacts` Pipeline (see the _Kicking off the "Git Artifacts" Azure Pipeline_ section below), therefore we can only proceed with that Pipeline once both `git-sdk-64-extra-artifacts` and `git-sdk-32-extra-artifacts` runs are finished; Ironically, having to re-build the artifacts slows us down if we need to accommodate for last-minute component updates. - -It is important to wait for the Pipelines mentioned above to finish before moving on to the respective next Pipeline, otherwise the last-minute component update won't make it into the final Git artifacts. +Note: Historically, we used the artifacts of the [`git-sdk-64-extra-artifacts`](https://dev.azure.com/git-for-windows/git/_build?definitionId=29&_a=summary) and the [`git-sdk-32-extra-artifacts` Pipeline](https://dev.azure.com/git-for-windows/git/_build?definitionId=30&_a=summary) Pipelines that were triggered automatically by pushes to `git-sdk-64` and `git-sdk-32`, respectively, and we had to wait for them to complete before proceeding. As of June 17th, 2022, this is no longer necessary. # Rebasing Git for Windows' patches From 86a41d5123d9a07bf3e7f11ae5f9f58fb3bb4f98 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Fri, 17 Jun 2022 14:45:06 +0200 Subject: [PATCH 532/591] Releasing Git for Windows: link to the "new git version" issue Signed-off-by: Johannes Schindelin --- Releasing-Git-for-Windows.md | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/Releasing-Git-for-Windows.md b/Releasing-Git-for-Windows.md index b6d73ca0014c8d..772af8e9a2484b 100644 --- a/Releasing-Git-for-Windows.md +++ b/Releasing-Git-for-Windows.md @@ -82,6 +82,13 @@ For convenience, this can be automated via this alias: pre-release-pr-range-diff = "!set -x && x=\"$(git range-diff -s origin/main^{/^Start.the}..origin/main origin/main^{/^Start.the}^..HEAD^{/^Start.the}^ | sed -n 's/^[ 0-9]*: \\([0-9a-f][0-9a-f]*\\) [=!] [ 0-9]*: \\([0-9a-f][0-9a-f]*\\).*/-e \"s\\/\\1\\/\\1 (upstream: \\2)\\/\"/p')\" && git gfw-range-diff origin/main HEAD | sed -e 's/^[ 0-9]*: [0-9a-f]* [=!]/ &/' -e 's/^[ 0-9]*: [0-9a-f]* /+&/' | eval sed ${x:-\\'\\'} | clip.exe" ``` +# Linking the "New git version" issue + +When a new version is tagged in [upstream git](https://github.com/git/git), the "Monitor Component Updates" pipeline in Git for Windows creates an issue for the version ([example](https://github.com/git-for-windows/git/issues/3515)). For tracking & automation purposes, you should: + +- link the issue to the pull request created in the previous step +- add the issue to the current "Next release" milestone ([example](https://github.com/git-for-windows/git/milestone/67)) + # Kicking off the "Git Artifacts" Azure Pipeline Direct your browser to https://dev.azure.com/git-for-windows/git/_build?definitionId=34&_a=summary and queue a new build ("Run pipeline") with the build variable `use.branch` set to something like `rebase-to-v2.27.0@https://github.com/dscho/git` and `Branch/tag` set to the PR's tip commit (e.g. `refs/pull/2645/head`). From d892aa4d4b53d528d7d24bf93ec7d7fa6c482ab3 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Fri, 17 Jun 2022 14:47:10 +0200 Subject: [PATCH 533/591] Releasing Git for Windows: note that Pacman takes a long time Folks who did the release for the first time indicated to be surprised by this ;-) Signed-off-by: Johannes Schindelin --- Releasing-Git-for-Windows.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/Releasing-Git-for-Windows.md b/Releasing-Git-for-Windows.md index 772af8e9a2484b..d0b5c1946a7415 100644 --- a/Releasing-Git-for-Windows.md +++ b/Releasing-Git-for-Windows.md @@ -112,6 +112,8 @@ The idea here is to download the `Git--64-bit.exe` artifact from the Pi This one is _really_ easy (as long as nothing is broken...): https://dev.azure.com/git-for-windows/git/_release?definitionId=1&_a=releases +Note: The `pacman` upload always takes this long. + Sadly, things are broken a lot. In those cases, the logs have to be analyzed, and the Pipeline needs to be edited (when it asks whether you want to edit for this release only, do say that you want that), and the deployment has to be restarted. Examples for failures that happened in the past: - Timeouts while uploading the GitHub Release. In that case, the partially-populated draft release has to be deleted manually (first delete the assets, or it won't delete the release), and then re-deploy. From 0454987f8f3d69484691ad4654799b8f03bb7ca3 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Fri, 17 Jun 2022 14:47:43 +0200 Subject: [PATCH 534/591] Releasing Git for Windows: we do push to `main` more quickly, nowadays Signed-off-by: Johannes Schindelin --- Releasing-Git-for-Windows.md | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/Releasing-Git-for-Windows.md b/Releasing-Git-for-Windows.md index d0b5c1946a7415..03ba461876d18e 100644 --- a/Releasing-Git-for-Windows.md +++ b/Releasing-Git-for-Windows.md @@ -122,11 +122,16 @@ Sadly, things are broken a lot. In those cases, the logs have to be analyzed, an - Something was pushed to the `main` branch in the meantime, and the Release Pipeline could not handle that. In this instance, the Pipeline was edited to `git pull && git push` if the `git push` failed. More complex scenarios might involve pulling a branch from a personal fork, e.g. if merge conflicts had to be resolved. -# Pushing directly to `main` to close the PR and set the stage for the Azure Pipeline +# Pushing directly to `main` to close the PR and set the stage for uploading the release as a new snapshot -This step is trivial: `git push origin main` +This step is trivial: `git push origin :main` where `` is something like `rebase-to-v2.37.0`. + +This will trigger another "Git artifacts" run, which will figure out that there is a GitHub Release for that commit, download those artifacts, then trigger a run of [the `Snapshots` Release Pipeline](https://dev.azure.com/git-for-windows/git/_release?definitionId=2&view=mine&_a=releases), which will then upload [the snapshot](https://wingit.blob.core.windows.net/files/index.html). + +It is important to wait with pushing to `main` until there is a GitHub Release, otherwise the "Git artifacts" Pipeline would build _another_ set of artifacts and upload those, but we do want to use the same artifacts as were uploaded to GitHub Releases. + +Note: The idea is to push to `main` relatively soon after the Release Pipeline finished, to keep the Pacman repository, the [snapshots](https://wingit.blob.core.windows.net/files/index.html) and the `main` branches as aligned as possible. -Note: traditionally, we do _not_ do that for `-rc0` releases, as they typically happen something like two-and-a-half weeks before the final release, and in rare cases we might need the flexibility to allow for a _real_ quick release (e.g. if a security vulnerability was not disclosed responsibly). The idea going forward, however, is to push to `main` relatively soon after the Release Pipeline finished, to keep the Pacman repository, the [snapshots](https://wingit.blob.core.windows.net/files/index.html) and the `main` branches as aligned as possible. # How to release a quick-fix release From 6e16b01987867d03e9657e680f29f0c4804f192c Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Tue, 12 Jul 2022 11:52:50 +0200 Subject: [PATCH 535/591] There is not actually any "th" sound in "GitHub" --- Auto-launching-ssh-agent-when-git-starts.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Auto-launching-ssh-agent-when-git-starts.md b/Auto-launching-ssh-agent-when-git-starts.md index 536dd183e147cd..23e505ecff956a 100644 --- a/Auto-launching-ssh-agent-when-git-starts.md +++ b/Auto-launching-ssh-agent-when-git-starts.md @@ -8,7 +8,7 @@ Run the ssh agent: This should work both in a `cmd` and `bash` shell and can be included in `~/.profile` or `~/.bashrc`. -The [Github instructions](https://help.github.com/articles/working-with-ssh-key-passphrases/#auto-launching-ssh-agent-on-msysgit) are still valid but not needed anymore. +The [GitHub instructions](https://help.github.com/articles/working-with-ssh-key-passphrases/#auto-launching-ssh-agent-on-msysgit) are still valid but not needed anymore. ## Manually From d345460744eb0c58a6fd8cedc47ae878df1c2f0d Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Tue, 12 Jul 2022 19:32:55 +0200 Subject: [PATCH 536/591] Git for Windows v2.37.1 is the latest security bug fix release --- FAQ.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/FAQ.md b/FAQ.md index a2989987799d96..468b83c1085ccd 100644 --- a/FAQ.md +++ b/FAQ.md @@ -27,7 +27,7 @@ In the meantime you could try: In general, yes: it is a good idea to stay up-to-date. -If you have a version older than 2.36.0, it is *highly* advisable to upgrade. A couple of Git versions came with important fixes to security-relevant vulnerabilities: 2.36.0, 2.35.3, 2.35.3, 2.30.2, 2.30.0(2), 2.29.2(3), 2.29.2(2), 2.26.1, 2.24.1(2), 2.17.1(2), 2.14.1, 2.7.4, 2.7.0, 2.6.1, 2.5.2, 1.9.5-preview20150319, and 1.9.5-preview20141217. +If you have a version older than 2.37.1, it is *highly* advisable to upgrade. A couple of Git versions came with important fixes to security-relevant vulnerabilities: 2.37.1, 2.36.0, 2.35.3, 2.35.3, 2.30.2, 2.30.0(2), 2.29.2(3), 2.29.2(2), 2.26.1, 2.24.1(2), 2.17.1(2), 2.14.1, 2.7.4, 2.7.0, 2.6.1, 2.5.2, 1.9.5-preview20150319, and 1.9.5-preview20141217. ## What is the release cadence of Git for Windows? From 4c978c2c8953dbd68726216326bf61c52ecd960b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Matthias=20A=C3=9Fhauer?= Date: Wed, 27 Jul 2022 11:26:52 +0200 Subject: [PATCH 537/591] Updated FAQ (markdown) --- FAQ.md | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/FAQ.md b/FAQ.md index 468b83c1085ccd..de16c0a1106850 100644 --- a/FAQ.md +++ b/FAQ.md @@ -1,6 +1,10 @@ ## Which versions of Windows are supported? -Git for Windows currently works with all recent, commercially released x86 32 bit and 64 bit versions of Windows, starting with Windows Vista. +Git for Windows currently works with all recent, commercially released x86 32 bit and 64 bit versions of Windows, starting with Windows 7 SP1. + +*** +NOTE: Git for Windows version [2.37.1](https://github.com/git-for-windows/git/releases/tag/v2.37.1.windows.1) was the last version supporting Windows Vista and Server 2008. +*** *** NOTE: Git for Windows version [2.10.0](https://github.com/git-for-windows/git/releases/tag/v2.10.0.windows.1) was the last version supporting Windows XP and Server 2003. From e1ce019a9a2f2ba341e2a690e207829be14a6dec Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Thu, 28 Jul 2022 11:17:26 +0200 Subject: [PATCH 538/591] Add a page explaining why Git for Windows does not work with Mandatory ASLR --- ...ory-Address-Space-Layout-Randomization?.md | 25 +++++++++++++++++++ 1 file changed, 25 insertions(+) create mode 100644 Why-does-Git-for-Windows-not-work-with-Mandatory-Address-Space-Layout-Randomization?.md diff --git a/Why-does-Git-for-Windows-not-work-with-Mandatory-Address-Space-Layout-Randomization?.md b/Why-does-Git-for-Windows-not-work-with-Mandatory-Address-Space-Layout-Randomization?.md new file mode 100644 index 00000000000000..221571a668e82e --- /dev/null +++ b/Why-does-Git-for-Windows-not-work-with-Mandatory-Address-Space-Layout-Randomization?.md @@ -0,0 +1,25 @@ +A common source for exploits has been to cause buffer overflows. When executables are loaded to the same address range every time they are launched, such buffer overflows can rely on encountering the same scenario every time, which makes it easier to exploit them. + +To remedy that, [Address Space Layout Randomization (ASLR)](https://msrc-blog.microsoft.com/2013/12/11/software-defense-mitigating-common-exploitation-techniques/) has been invented. Essentially, it causes executables and dynamic libraries to be loaded into somewhat random memory locations, making the common buffer overflows much harder to exploit. There is even an option to require all programs to use ASLR, whether the executables indicate that they want that or not: [Mandatory ASLR](https://msrc-blog.microsoft.com/2017/11/21/clarifying-the-behavior-of-mandatory-aslr/). + +As per [an MSYS2 post](https://www.msys2.org/news/#2021-01-31-aslr-enabled-by-default), MSYS2 enabled ASLR, and so should Git for Windows. So why doesn't Git for Windows work under Mandatory ASLR? + +Well, that MSYS2 post left out something crucial. To understand that, we need to add a bit of background first. Historically, most Open Source software depends on POSIX semantics that are not available on Windows, e.g. the often-mentioned `fork()` syscall (there were some subsystems in Windows that supported that syscall, but programs linking to the regular Win32 API cannot use that). Some software has been ported to pure Win32 calls (e.g. using `CreateProcessW()`), but the easier approach is to use a POSIX emulation layer like [Cygwin](https://cygwin.com/) (of which [the MSYS2 runtime](https://github.com/msys2/msys2-runtime) is a close derivative). That "ease of porting" comes at the cost of performance, and of the inability to use ASLR. + +MSYS2's packages that depend on that POSIX emulation layer are called "MSYS packages", the other packages are called "MINGW packages". [That MSYS2 post](https://www.msys2.org/news/#2021-01-31-aslr-enabled-by-default) did not make it clear, but it talked only about the MINGW packages. It is a bit clearer in [the ticket](https://github.com/msys2/MINGW-packages/issues/6674) that lead to the work that was described in that post (note that it is a ticket in the `msys2/MINGW-packages` repository). + +Git for Windows bundles some MINGW programs (such as `git.exe`) and some MSYS programs (such as `bash.exe`). The MINGW programs already use ASLR, the MSYS programs do not. See for yourself: + +PS C:\> dumpbin /headers 'C:\Program Files\Git\mingw64\bin\libcurl-4.dll' | grep -i dynamic + Dynamic base +PS C:\> dumpbin /headers 'C:\Program Files\Git\mingw64\bin\git.exe' | grep -i dynamic + Dynamic base +PS C:\> dumpbin /headers 'C:\Program Files\Git\usr\bin\bash.exe' | grep -i dynamic +PS C:\> dumpbin /headers 'C:\Program Files\Git\usr\bin\msys-2.0.dll' | grep -i dynamic + +The "Dynamic base" indicates that ASLR is enabled. The absence indicates that it is disabled. By the way, that is no different from regular MSYS2's situation: + +PS C:\> dumpbin /headers 'C:\msys64\usr\bin\msys-2.0.dll' | grep -i dynamic +PS C:\> dumpbin /headers 'C:\msys64\usr\bin\bash.exe' | grep -i dynamic + +There have been many posts to Cygwin asking for ASLR support (and let's make this utterly clear: if Cygwin cannot enable ASLR, neither can the MSYS2 runtime, it's either both or none), e.g. [here](https://cygwin.cygwin.narkive.com/Zrqc0stg/aslr-breaks#), [here](https://x.cygwin.com/ml/cygwin/current/244156.html) and [here](https://www.mail-archive.com/cygwin%40cygwin.com/msg165776.html). Noone has found any answer to the fundamental design problem yet: How could `fork()` be emulated without requiring an identical address for the Cygwin heap in all parent/child processes? \ No newline at end of file From bbc55441d513726ba1c18707c2cb681e831860f9 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Thu, 28 Jul 2022 11:20:09 +0200 Subject: [PATCH 539/591] Rename the page to allow cloning on Windows (question marks are not permitted in file names) --- ...-not-work-with-Mandatory-Address-Space-Layout-Randomization.md | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename Why-does-Git-for-Windows-not-work-with-Mandatory-Address-Space-Layout-Randomization?.md => Why-Git-for-Windows-does-not-work-with-Mandatory-Address-Space-Layout-Randomization.md (100%) diff --git a/Why-does-Git-for-Windows-not-work-with-Mandatory-Address-Space-Layout-Randomization?.md b/Why-Git-for-Windows-does-not-work-with-Mandatory-Address-Space-Layout-Randomization.md similarity index 100% rename from Why-does-Git-for-Windows-not-work-with-Mandatory-Address-Space-Layout-Randomization?.md rename to Why-Git-for-Windows-does-not-work-with-Mandatory-Address-Space-Layout-Randomization.md From 13f3486e2dc70b9f30dfedf480ea09d1e567ecce Mon Sep 17 00:00:00 2001 From: maiyazfc <110793760+maiyazfc@users.noreply.github.com> Date: Tue, 9 Aug 2022 05:27:25 +0800 Subject: [PATCH 540/591] =?UTF-8?q?=E7=94=9F=E7=9A=84=20=E8=B4=A3=E5=A4=87?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- ...61\347\232\204\351\224\231\350\257\257.md" | 25 +++++++++++++++++++ 1 file changed, 25 insertions(+) create mode 100644 "\346\224\271\346\216\211\350\207\252\345\267\261\347\232\204\351\224\231\350\257\257.md" diff --git "a/\346\224\271\346\216\211\350\207\252\345\267\261\347\232\204\351\224\231\350\257\257.md" "b/\346\224\271\346\216\211\350\207\252\345\267\261\347\232\204\351\224\231\350\257\257.md" new file mode 100644 index 00000000000000..2b4ed84c1b5ce2 --- /dev/null +++ "b/\346\224\271\346\216\211\350\207\252\345\267\261\347\232\204\351\224\231\350\257\257.md" @@ -0,0 +1,25 @@ +FreeBSD CI 构建(在 Cirrus-CI 上)一直失败 +'t9001-send-email.sh' 很长一段时间,从错误 +与 Perl 安装相关的运行时链接器: + + $ GIT_SEND_EMAIL_NOTTY=1 git 发送电子邮件\ + '--from=Example ' '--to=nobody@example.com' \ + '--smtp-server=/tmp/cirrus-ci-build/t/trash directory.t9001-send-email/fake.sendmail' \ + --compose '--subject=foo' 0001-Second.patch + ld-elf.so.1:/usr/local/lib/perl5/5.32/mach/CORE/libperl.so.5.32:未定义符号“strerror_l@FBSD_1.6” + +第一个实例在 t9001.6 中,但在几次测试中同样失败 +在这个文件中。 + +我们使用的 FreeBSD 映像是 FreeBSD 12.2,因为它不受支持 +2022 年 3 月 31 日 [1]。切换到受支持的版本 12.3, +使此错误消失 [2]。 + +将我们使用的映像更改为 FreeBSD 12.3。 + +[1] https://www.freebsd.org/security/unsupported/ +[2] https://lore.kernel.org/git/9cc31276-ab78-fa8a-9fb4-b19266911211@gmail.com/ + +审核人:Carlo Marcelo Arenas Belón +签字人:Philippe Blain +签字人:Junio C Hamano ## *** ** \ No newline at end of file From e97bfee739b613385b169d048bfb09e02ef23033 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Wed, 10 Aug 2022 09:53:56 +0200 Subject: [PATCH 541/591] =?UTF-8?q?Revert=20"=E7=94=9F=E7=9A=84=20?= =?UTF-8?q?=E8=B4=A3=E5=A4=87"?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit This was most likely added by mistake. I opened https://github.com/git-for-windows/git/discussions/3979 trying to find out what was intended. This reverts commit 13f3486e2dc70b9f30dfedf480ea09d1e567ecce. Signed-off-by: Johannes Schindelin --- ...61\347\232\204\351\224\231\350\257\257.md" | 25 ------------------- 1 file changed, 25 deletions(-) delete mode 100644 "\346\224\271\346\216\211\350\207\252\345\267\261\347\232\204\351\224\231\350\257\257.md" diff --git "a/\346\224\271\346\216\211\350\207\252\345\267\261\347\232\204\351\224\231\350\257\257.md" "b/\346\224\271\346\216\211\350\207\252\345\267\261\347\232\204\351\224\231\350\257\257.md" deleted file mode 100644 index 2b4ed84c1b5ce2..00000000000000 --- "a/\346\224\271\346\216\211\350\207\252\345\267\261\347\232\204\351\224\231\350\257\257.md" +++ /dev/null @@ -1,25 +0,0 @@ -FreeBSD CI 构建(在 Cirrus-CI 上)一直失败 -'t9001-send-email.sh' 很长一段时间,从错误 -与 Perl 安装相关的运行时链接器: - - $ GIT_SEND_EMAIL_NOTTY=1 git 发送电子邮件\ - '--from=Example ' '--to=nobody@example.com' \ - '--smtp-server=/tmp/cirrus-ci-build/t/trash directory.t9001-send-email/fake.sendmail' \ - --compose '--subject=foo' 0001-Second.patch - ld-elf.so.1:/usr/local/lib/perl5/5.32/mach/CORE/libperl.so.5.32:未定义符号“strerror_l@FBSD_1.6” - -第一个实例在 t9001.6 中,但在几次测试中同样失败 -在这个文件中。 - -我们使用的 FreeBSD 映像是 FreeBSD 12.2,因为它不受支持 -2022 年 3 月 31 日 [1]。切换到受支持的版本 12.3, -使此错误消失 [2]。 - -将我们使用的映像更改为 FreeBSD 12.3。 - -[1] https://www.freebsd.org/security/unsupported/ -[2] https://lore.kernel.org/git/9cc31276-ab78-fa8a-9fb4-b19266911211@gmail.com/ - -审核人:Carlo Marcelo Arenas Belón -签字人:Philippe Blain -签字人:Junio C Hamano ## *** ** \ No newline at end of file From 37363ba88a406f1f01d7ff1507ebf0f93aead1a8 Mon Sep 17 00:00:00 2001 From: Martin 2bam Date: Wed, 21 Sep 2022 03:51:54 +0200 Subject: [PATCH 542/591] Changes discussed in issue #4016 --- FAQ.md | 18 +++++++++++++++++- 1 file changed, 17 insertions(+), 1 deletion(-) diff --git a/FAQ.md b/FAQ.md index de16c0a1106850..243dae9bb3fa31 100644 --- a/FAQ.md +++ b/FAQ.md @@ -100,10 +100,26 @@ In order to instruct git to use domain authentication, prefix the server name wi See also: [Clone an existing Git repo - Azure Repos](https://docs.microsoft.com/en-us/azure/devops/repos/git/clone) -## I get "Permission denied (publickey)." when using git pull +## I get "Permission denied (publickey)." when using git pull or git clone +### DSA keys Some DSA keys are not considered secure anymore by OpenSSH 7. Adding "PubkeyAcceptedKeyTypes ssh-dss" to ~/.ssh/config helps. +### Running without Git Bash +If you choose to use OpenSSH that comes with git during installation (default option) and wish to work from Windows' Command Prompt (cmd) or PowerShell instead of Git Bash you should make sure: + +1. You're calling the correct executables. +Windows comes with a different OpenSSH distribution and by default you might be calling it while git commands use its own. +Set the environment PATH to use the git installation ssh commands first, those are usually at `C:\Program Files\Git\usr\bin`. +In CMD: `set PATH=C:\Program Files\Git\usr\bin;%PATH%` +In PowerShell: `$Env:PATH = "C:\Program Files\Git\usr\bin;$Env:PATH"` +This will make sure, for example, that you add the private keys to the correct _ssh-agent service_ when calling `ssh-add`. +Otherwise you might be asked to introduce the passphrase on each git command call that connects to a remote repository. + +2. Git's ssh is able to connect to the ssh-agent. +In order to connect to the _ssh-agent service_, git's ssh needs to know _how_. This is accomplished by two environment variables called `SSH_AGENT_PID` and `SSH_AUTH_SOCK`. +Luckily, there is a convenient script `start-ssh-agent.cmd` included with the git installation you can call to set this up. The values are dynamic and only valid after calling the script. Forgetting to set them will fail silently, so be sure to call the script each time you open a new command prompt. + ## Switch locale for git-bash launcher (of Git for Windows SDK) Some developers want to start git-bash (of Git for Windows SDK) with a different language. From cc4d91453acbf955b8c2e136a53ae82f5ab58fa6 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Tue, 18 Oct 2022 20:31:48 +0200 Subject: [PATCH 543/591] Mention that Git for Windows v2.38.1 is required to stay safe, for now --- FAQ.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/FAQ.md b/FAQ.md index 243dae9bb3fa31..4aa43eadffd9eb 100644 --- a/FAQ.md +++ b/FAQ.md @@ -31,7 +31,7 @@ In the meantime you could try: In general, yes: it is a good idea to stay up-to-date. -If you have a version older than 2.37.1, it is *highly* advisable to upgrade. A couple of Git versions came with important fixes to security-relevant vulnerabilities: 2.37.1, 2.36.0, 2.35.3, 2.35.3, 2.30.2, 2.30.0(2), 2.29.2(3), 2.29.2(2), 2.26.1, 2.24.1(2), 2.17.1(2), 2.14.1, 2.7.4, 2.7.0, 2.6.1, 2.5.2, 1.9.5-preview20150319, and 1.9.5-preview20141217. +If you have a version older than 2.38.1, it is *highly* advisable to upgrade. A couple of Git versions came with important fixes to security-relevant vulnerabilities: 2.38.1, 2.37.1, 2.36.0, 2.35.3, 2.35.3, 2.30.2, 2.30.0(2), 2.29.2(3), 2.29.2(2), 2.26.1, 2.24.1(2), 2.17.1(2), 2.14.1, 2.7.4, 2.7.0, 2.6.1, 2.5.2, 1.9.5-preview20150319, and 1.9.5-preview20141217. ## What is the release cadence of Git for Windows? From fbcfbf1bc843c5b6d2e84c6097c2907e895308e5 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Mon, 14 Nov 2022 16:25:15 +0100 Subject: [PATCH 544/591] Document how to backport git.git patches Signed-off-by: Johannes Schindelin --- Backporting-upstream-Git-patches.md | 58 +++++++++++++++++++++++++++++ 1 file changed, 58 insertions(+) create mode 100644 Backporting-upstream-Git-patches.md diff --git a/Backporting-upstream-Git-patches.md b/Backporting-upstream-Git-patches.md new file mode 100644 index 00000000000000..0502a024639c7f --- /dev/null +++ b/Backporting-upstream-Git-patches.md @@ -0,0 +1,58 @@ +# How to backport a patch (series) that was contributed to upstream Git + +Git for Windows' [release cadence](https://github.com/git-for-windows/git/security/policy#supported-versions) closely follows the [release cycle of the "upstream" Git project](https://tinyurl.com/gitcal). + +Sometimes patches that already made it into upstream Git, but that have not been released as part of an official version, are important enough for Git for Windows that they need to be "backported", i.e. they to be integrated into Git for Windows' `main` branch. + +Contributions to the upstream Git project [are only accepted in the form of patches or patch series sent via mail to the Git mailing list](https://git-scm.com/docs/SubmittingPatches#send-patches). This makes backporting them a bit more challenging than if regular Git tools like `git pull` could be used. + +## GitGitGadget contributions + +If the contribution was sent to the mailing list via [GitGitGadget](https://gitgitgadget.github.io/) (which is a tool allowing to send GitHub PRs to the Git mailing list without having to fiddle with mail programs until they send the contribution in the precise form that the Git project wants them), the backporting process is comparatively hassle-free: GitGitGadget contributions have a fetch'able Git branch and the PRs contain other relevant information such as the date and the commit which integrated the patches into Git's main branch. + +Take for example [the "ci: use a newer `github-script` version" patch that avoids warnings in CI runs about using deprecated Actions/node.js versions](https://lore.kernel.org/git/pull.1387.git.1667902408921.gitgitgadget@gmail.com/): That mail contains the information in the footer from which PR it originated (in this example, https://github.com/gitgitgadget/git/pull/1387). That PR receives labels depending on the contribution process: `seen` if it was integrated into the daily hodgepodge branch of Git, `next` once the contribution advanced to the "let's cook this for a bit" stage, and `master` once the contribution has been slated for the next official Git version. + +That PR also receives a comment once the patches have been integrated into a tentative topic branch, in this example ["js/ci-set-output"](https://github.com/gitgitgadget/git/pull/1387#issuecomment-1307968188). Following the [`js/ci-set-output` link](https://github.com/gitgitgadget/git/commits/js/ci-set-output), you can see the Git commits of the topic branch in which for upstream Git tracks the patches. You can also see the original shape of the contribution by clicking on the link to the PR branch at the top of the PR page (in the example: ["dscho:upgrade-github-script-version"](https://github.com/dscho/git/tree/upgrade-github-script-version)). + +When backporting patches, the Git for Windows project typically prefers the shape that was already accepted upstream, i.e. once it made it into `next`, we backport the _upstream topic branch_'s commits. + +The typical way to backport such a branch is to first see whether it needs to be rebased at all, i.e. if there are any additional commits between Git for Windows' `main` branch and that topic branch. The quickest way is to direct a web browser to a URL like this: https://github.com/git-for-windows/git/compare/main...gitgitgadget:js/ci-set-output. + +### Scenario: The upstream topic branch can be used as-is + +If that comparison only shows the commits of the contribution, we're almost done: hit the "Create pull request" button on that page and populate the PR description with [informative, enjoyable content](https://github.blog/2022-06-30-write-better-commits-build-better-projects/), i.e. providing enough context and motivation to understand why the patches need to be backported, enough detail to understand the contribution, how it solves the issue(s) at hand and what other impact the patches have, and of course add links to the relevant discussions such as the Git mailing list thread, the relevant Git for Windows tickets (if any), etc + +### Scenario: The upstream topic branch _cannot_ be used as-is + +There seems to be little rhyme nor reason on top of which commit, precisely, the Git maintainer decides to apply the patches received via the Git mailing list. At times it seems rather arbitrary and is not always conducive to using the upstream topic branch in Git for Windows as-is. In the example mentioned above, the comparison between Git for Windows' `main` branch and the topic branch showed 386 commits instead of the single desired one, at the time of writing. + +In such scenarios, a backport involves creating a local branch from the upstream topic branch, rebasing the patch on top of a more suitable base commit (typically, a Git tag, or a Git for Windows tag if necessary to avoid merge conflicts, falling back to the tip of Git for Windows' `main` branch), then pushing the result and opening a PR from that. In the example above: + +1. `git fetch https://github.com/gitgitgadget/git js/ci-set-output` +2. `git switch -c js/ci-set-output FETCH_HEAD` +3. `git rebase -i --onto v2.38.0 HEAD~1 # increase 1 accordingly for multiple patches` +4. `git push HEAD` + +After that, as detailed above, open a PR with an [informative, enjoyable description](https://github.blog/2022-06-30-write-better-commits-build-better-projects/), i.e. providing enough context and motivation to understand why the patches need to be backported, enough detail to understand the contribution, how it solves the issue(s) at hand and what other impact the patches have, and of course add links to the relevant discussions such as the Git mailing list thread, the relevant Git for Windows tickets (if any), etc + +## Non-GitGitGadget contributions + +If the contribution that needs to be backported did _not_ use GitGitGadget, it can become a bit more daunting, in particular when going off of a bug report on the Git mailing list. The first step, then, is to find the relevant topic branch (if any). + +### If there is not even an upstream topic branch yet + +The most challenging scenario is when there exists a patch that needs to be backported but it has not been integrated into Git yet (not even into the `seen` branch), and all one has to go for is a thread on the Git mailing list (or even just a Message-Id, which can be turned into a link to the Git mailing list archive via https://lore.kernel.org/git/). + +The first order of business is to find the mail containing the patch. Often, these mails have either been linked to from a reply to the bug report, or they are sent as replies directly, with the mail's subject line starting with `[PATCH]`. If that is not the case, the mail containing the patch can be identified by scrolling all the way to the beginning of the mail thread at the bottom of the lore.kernel.org page that has the bug report, then click the "nested" link so that all mails in the thread are shown, and then using the browser's "Find" functionality to search for the needle "diff --git". + +Once the mail containing the patch was found, the [`apply-from-lore.sh` script](https://github.com/git-for-windows/build-extra/blob/HEAD/apply-from-lore.sh) can be used with the mail's permalink to apply it to a local branch in a checkout of [the `git-for-windows/git` repository](https://github.com/git-for-windows/git/). + +Then, continue as detailed in the first sections above. + +### If there _is_ an upstream topic branch + +Sometimes, contributors are asked to backport patches that have made it into upstream Git. If it is already clear what name the Git maintainer gave the topic branch, continue as outlined in the corresponding subsection of [the "GitGitGadget" section](#gitgitgadget-contributions) above. + +If it is unclear what the name of that topic branch is, search for the first line of a commit message ("commit subject" or "oneline") of that contribution in the [What's cooking mail](https://github.com/git/git/blob/todo/whats-cooking.txt); The name of the topic branch will be mentioned above the line mentioning the commit subject. + +If all else fails, you can also try to fetch the `seen` branch and search for the topic branch via `git show FETCH_HEAD^{/}` where the regular expression matches the commit subject in question. \ No newline at end of file From 21377466008d5ca519f990076d1c59de2567842a Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Sun, 20 Nov 2022 23:58:45 +0100 Subject: [PATCH 545/591] Explain how to develop the installer's pages efficiently --- Making-an-installer.md | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/Making-an-installer.md b/Making-an-installer.md index 0ada0e63d9edb1..5e768c67d95eb2 100644 --- a/Making-an-installer.md +++ b/Making-an-installer.md @@ -4,6 +4,15 @@ Download the [Git for Windows SDK](https://gitforwindows.org/#download-sdk), ins If you need to include a Git version built with custom patches, call `sdk cd git`, then make sure that it is at the commit you want, then call `sdk build git-and-installer`. +## Debugging/Developing a single installer "wizard page" + +Sometimes the wording needs to be changed, or the layout, or something, in a single page of the installer. To avoid having to build the entire installer (and compressing all of Git for Windows), run `sdk cd installer` and run `./release.sh -d `. For example, to modify the page where Git's default editor can be configured, run this: + +``` +sdk cd installer +./release.sh -d Editor +``` + # Detailed overview As the installer is made by putting together files from the Git SDK, it is advisable to update those files first. To update the packages, call `pacman -Syu` ([caveats apply](https://github.com/git-for-windows/git/wiki/Package-management#updating-msys2-runtime-pacman-and-bash)). From 2ba8cbf8efee08451c5c284686aa70790ba857f6 Mon Sep 17 00:00:00 2001 From: Dennis Ameling Date: Tue, 27 Dec 2022 23:17:00 +0100 Subject: [PATCH 546/591] wiki: rename git-extra to mingw-w64-git-extra In a recent commit, we started publishing the mingw-w64-git-extra package in addition to git-extra. We intend to completely remove the old git-extra package over time, but let's start using the new mingw-w64-git-extra prefix now. More background on this change can be found in the attached commit. Ref: https://github.com/git-for-windows/build-extra/commit/3f26b1b0ca8bed41124b893783afc848fbbd94f6 Signed-off-by: Dennis Ameling --- Install-inside-MSYS2-proper.md | 4 ++-- ...date-inside-MSYS2,-Cygwin-or-Git-for-windows-itself.md | 2 +- Making-an-installer.md | 8 ++++---- Package-management.md | 4 ++-- Technical-overview.md | 4 ++-- Updating-your-SDK.md | 2 +- 6 files changed, 12 insertions(+), 12 deletions(-) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index ebb3311a1c0fb9..36c106d9fdadcc 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -51,7 +51,7 @@ Here are the steps to install the 64-bit version of Git for Windows to be run in 5. And finally install the packages containing Git, its documentation and some extra things: - pacman -S mingw-w64-x86_64-{git,git-doc-html,git-doc-man} git-extra + pacman -S mingw-w64-x86_64-{git,git-doc-html,git-doc-man} mingw-w64-x86_64-git-extra Now you can close the current shell and open a MINGW64 shell (`msys2_shell.cmd -mingw64`) to check that everything went well. Run `git --version` and it should output something like `git version 2.31.0.windows.1` (or newer). @@ -72,7 +72,7 @@ Git for Windows carries an `msys2-runtime` different from upstream MSYS2, see [i Git for Windows also patches some other packages like cURL and OpenSSL. It unfortunately sometimes causes some packages to be behind in terms of their version, but keeping the upstream packages would most probably lead to a severely broken Git. -The `git-extra` package modifies the MSYS2 environment heavily (sometimes in ways that are tedious to undo). The package can be skipped if you want to keep your MSYS2 pristine. As of this writing, the package: +The `mingw-w64-git-extra` package modifies the MSYS2 environment heavily (sometimes in ways that are tedious to undo). The package can be skipped if you want to keep your MSYS2 pristine. As of this writing, the package: - brings the `git-for-windows-keyring` package as its dependency, but you can install it manually - adds the `sdk` command intended for developing Git for Windows diff --git a/Install-or-update-inside-MSYS2,-Cygwin-or-Git-for-windows-itself.md b/Install-or-update-inside-MSYS2,-Cygwin-or-Git-for-windows-itself.md index 5c132923b198fb..082f6784c1efb6 100644 --- a/Install-or-update-inside-MSYS2,-Cygwin-or-Git-for-windows-itself.md +++ b/Install-or-update-inside-MSYS2,-Cygwin-or-Git-for-windows-itself.md @@ -4,7 +4,7 @@ Instead of configuring and installing Git for Windows using `pacman`, this guide ## How to -With the script `getgit` introduced by [git-for-windows/build-extra#261](https://github.com/git-for-windows/build-extra/pull/261), you can download and run the script or just run `curl https://raw.githubusercontent.com/git-for-windows/build-extra/HEAD/git-extra/getgit | bash`. +With the script `getgit` introduced by [git-for-windows/build-extra#261](https://github.com/git-for-windows/build-extra/pull/261), you can download and run the script or just run `curl https://raw.githubusercontent.com/git-for-windows/build-extra/HEAD/mingw-w64-git-extra/getgit | bash`. The script would gather information about the current system ( *Msys / Cygwin* ), bitness, version of an already existed Git for Windows, version of the latest released Git for Windows... and then forge a proper download URL targeting a proper version of the `PortableGit` installer. With all the information prepared, the script would download the installer and unpack it to `/tmp`. After that, all the necessary files will be copied to a proper place inside the ( *Msys's / Cygwin's* ) file system without touching any existing **non-git-for-windows-exclusive** files. diff --git a/Making-an-installer.md b/Making-an-installer.md index 5e768c67d95eb2..83028d06e305c3 100644 --- a/Making-an-installer.md +++ b/Making-an-installer.md @@ -53,18 +53,18 @@ where `` is the Git version (please note that the `` cannot co # Why is this installer so much larger than the official installer? -Short version: you will need to run `make strip` in `/usr/src/git` before `make install`, and you will also need to run to call `pacman -S git-extra` afterwards. +Short version: you will need to run `make strip` in `/usr/src/git` before `make install`, and you will also need to run to call `pacman -S mingw-w64-x86_64-git-extra` (or `mingw-w64-clang-aarch64-git-extra` for arm64, or `mingw-w64-i686-git-extra` for x86) afterwards. ## Why `make strip`? The `make strip` command removes the debug information from the `.exe` files. That is not quite the same as the official release process does: it calls `cv2pdb` which splits out the debug information from the `.exe` files into separate `.pdb` files, but that processing is not defined in `/usr/src/git/Makefile`, but instead in `/usr/src/MINGW-packages/mingw-w64-git/PKGBUILD`. -## Why `pacman -S git-extra`? +## Why `pacman -S mingw-w64-x86_64-git-extra`? -The `pacman -S git-extra` part is defined elsewhere yet: in `/usr/src/build-extra/please.sh`. Its purpose is to replace many hardlinked copies in `/mingw64/libexec/git-core/git-*.exe` with what Git for Windows calls the "Git wrapper": a small executable that does nothing else but call `git.exe` with the appropriate subcommand name. +The `pacman -S mingw-w64-x86_64-git-extra` part is defined elsewhere yet: in `/usr/src/build-extra/please.sh`. Its purpose is to replace many hardlinked copies in `/mingw64/libexec/git-core/git-*.exe` with what Git for Windows calls the "Git wrapper": a small executable that does nothing else but call `git.exe` with the appropriate subcommand name. You see, many "built-in" commands are implemented right there in `git.exe`, with no need to actually execute anything else. For example, when you call `git show`, the show part is executed inside `git.exe` itself. This is in contrast to, say, `git send-email`, which actually executes `/mingw64/libexec/git-core/git-send-email` (a Perl script). For historical reasons, Git wants to provide also `git-show.exe` in `/mingw64/libexec/git-core/`, even if that is not at all necessary because the show command is a built-in command. Therefore, Git has this quirk where it first looks at the name of the executable via which it was called (e.g. if it was called via `/mingw64/libexec/git-core/git-show.exe`, it extracts the show part and knows that it should internally execute `git show` instead. And then, Git simply installs hardlinked copies of `git.exe` in `/mingw64/libexec/git-core/` for all built-in commands. -Since they are hard-links, they only use a minuscule amount of disk space. However, too many Git for Windows users looked at the disk usage of those hard-linked copies using the Windows Explorer, which historically completely ignored the fact that hard-linked copies did not use additional disk space (apart from the directory entry). As a consequence, we had many reports that Git for Windows occupied way too much space. That was not true, of course, but those reports took so much time to address that it was easier to install the Git wrapper (which is copied, but it is tiny compared to git.exe). \ No newline at end of file +Since they are hard-links, they only use a minuscule amount of disk space. However, too many Git for Windows users looked at the disk usage of those hard-linked copies using the Windows Explorer, which historically completely ignored the fact that hard-linked copies did not use additional disk space (apart from the directory entry). As a consequence, we had many reports that Git for Windows occupied way too much space. That was not true, of course, but those reports took so much time to address that it was easier to install the Git wrapper (which is copied, but it is tiny compared to git.exe). diff --git a/Package-management.md b/Package-management.md index db06e09ab19634..743df91361c02c 100644 --- a/Package-management.md +++ b/Package-management.md @@ -64,7 +64,7 @@ pacman -Qo If you want to rebuild a package, the first order of business is to know which repository has the metadata for the package. Git for Windows has three repositories containing such metadata: -- [build-extra](https://github.com/git-for-windows/build-extra) contains the `git-extra` package information, +- [build-extra](https://github.com/git-for-windows/build-extra) contains the `mingw-w64-git-extra` package information, - [MINGW-packages](https://github.com/git-for-windows/MINGW-packages) contains the information for the MINGW packages, i.e. packages that do not require any POSIX emulation; by convention, their package name have the `mingw-w64-` prefix, and - [MSYS2-packages](https://github.com/git-for-windows/MSYS2-packages) contains the information for all packages that require a POSIX emulation, such as Bash, OpenSSH, etc. The `MSYS2-packages` repository also contains the information of the package *providing* the POSIX emulation: [`msys2-runtime`](https://github.com/git-for-windows/msys2-runtime) (see also [Building msys2-runtime](Building-msys2-runtime)). @@ -133,4 +133,4 @@ The *Git for Windows*-specific packages are served by [Azure Blob Storage](https # Further reading - [Building new package versions](Building-new-package-versions) -- [Upgrading the `perl` component to a new version](Upgrading-the-%60perl%60-component-to-a-new-version) \ No newline at end of file +- [Upgrading the `perl` component to a new version](Upgrading-the-%60perl%60-component-to-a-new-version) diff --git a/Technical-overview.md b/Technical-overview.md index 0c18ab87d3d3db..ea47f3e2de7708 100644 --- a/Technical-overview.md +++ b/Technical-overview.md @@ -24,7 +24,7 @@ Afterwards you need to install git to make these changes available to the instal If you made any documentation changes, you need to install the documentation too: `make install-html && prefix=/mingw64 make -C contrib/subtree install-html` (the second make invocation installs the `git-subtree.html` which is otherwise missing and leads to an error by the portable installer). -In some cases, the change you want to make is not in git itself, but in the additional files needed to emulate the *ix environment git expects (things like `grep`, `find`, `cat`,...), or in additional helper files (e.g. `start-ssh-agent.cmd`). These files come from [Msys](https://github.com/git-for-windows/MSYS2-packages) and [Mingw](https://github.com/git-for-windows/MINGW-packages) packages. Please see the documentation for how to make [changes to these packages](Package-management#technical-details). Some files are also in the `build-extras` repo in the subdir [`git-extra`](https://github.com/git-for-windows/build-extra/tree/HEAD/git-extra) (the script which calls notepad as a commit message editor, diff filter for word files,...). The source code for these files are also under `/usr/src` but need to be checked out first (e.g. `cd /usr/src/MINGW-packages && git fetch && git checkout main`). +In some cases, the change you want to make is not in git itself, but in the additional files needed to emulate the *ix environment git expects (things like `grep`, `find`, `cat`,...), or in additional helper files (e.g. `start-ssh-agent.cmd`). These files come from [Msys](https://github.com/git-for-windows/MSYS2-packages) and [Mingw](https://github.com/git-for-windows/MINGW-packages) packages. Please see the documentation for how to make [changes to these packages](Package-management#technical-details). Some files are also in the `build-extras` repo in the subdir [`mingw-w64-git-extra`](https://github.com/git-for-windows/build-extra/tree/HEAD/mingw-w64-git-extra) (the script which calls notepad as a commit message editor, diff filter for word files,...). The source code for these files are also under `/usr/src` but need to be checked out first (e.g. `cd /usr/src/MINGW-packages && git fetch && git checkout main`). # Building an installer @@ -61,4 +61,4 @@ See also: * Running Git's [regression tests](Running-Git's-regression-tests) * MSYS/MINGW [package management](Package-management#technical-details) * [Updating the SDK](https://github.com/git-for-windows/git/wiki/Updating-your-SDK) -* [MSYS2](https://msys2.github.io/) \ No newline at end of file +* [MSYS2](https://msys2.github.io/) diff --git a/Updating-your-SDK.md b/Updating-your-SDK.md index 0187153fb6fee2..508d4b400a2d6f 100644 --- a/Updating-your-SDK.md +++ b/Updating-your-SDK.md @@ -19,7 +19,7 @@ The SDK ships with the script `update-via-pacman.bat` that you can: 1. Make sure that all Git SDK Bash windows are closed first, i.e. that no processes are running that might lock files that want to be updated 1. Start a `cmd` window -1. Run `update-via-pacman.bat` in the command window (it will always re-install the `git-extra` package at the end) +1. Run `update-via-pacman.bat` in the command window (it will always re-install the `mingw-w64-git-extra` package at the end) 1. Review/log the changes located in `/var/log/pacman.log`. While 'double-clicking' the file in the explorer will work, the cmd window will auto-close on completion limiting you options for reviewing the updates. Thus start a cmd window and run the .bat file from there. From 09742a677a8109e762f8c05b9842afcd251a8484 Mon Sep 17 00:00:00 2001 From: bakree25 <61651412+bakree25@users.noreply.github.com> Date: Fri, 30 Dec 2022 02:55:36 +0700 Subject: [PATCH 547/591] Updated Home (markdown) From 8b48b28545c38b29a3425ed39587e7ec8034a97f Mon Sep 17 00:00:00 2001 From: Parker Mauney Date: Mon, 9 Jan 2023 10:33:01 -0500 Subject: [PATCH 548/591] Fix malformed repository links --- Updating-your-SDK.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Updating-your-SDK.md b/Updating-your-SDK.md index 0187153fb6fee2..fd3428f03df2e9 100644 --- a/Updating-your-SDK.md +++ b/Updating-your-SDK.md @@ -1,6 +1,6 @@ # Installing the SDK -The [Git for Windows SDK release](https://github.com/git-for-windows/build-extra/releases/latest) is a self extracting and auto executing 7-zip archive that clones the latest version of files in [Git for Windows SDK 64 repository](https://github.com/git-for-windows/git-sdk-64`) using a temporary bundled git. For the [32 bit version](https://github.com/git-for-windows/git-sdk-32`) it also performs a run time optimisation on cloned DLLs (rebase). +The [Git for Windows SDK release](https://github.com/git-for-windows/build-extra/releases/latest) is a self extracting and auto executing 7-zip archive that clones the latest version of files in [Git for Windows SDK 64 repository](https://github.com/git-for-windows/git-sdk-64) using a temporary bundled git. For the [32 bit version](https://github.com/git-for-windows/git-sdk-32) it also performs a run time optimisation on cloned DLLs (rebase). This was previously called the 'net installer', see below. It provides everything required to bootstrap a development environment, even if no git is available (or an unstable one is being worked on). From c3f0ffd2c530e2d67b9b191ed4bb7245a0032c0b Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Mon, 23 Jan 2023 13:02:40 +0100 Subject: [PATCH 549/591] Mention that Git for Windows v2.39.1 is required to stay safe, for now --- FAQ.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/FAQ.md b/FAQ.md index 4aa43eadffd9eb..92d9e08534d47f 100644 --- a/FAQ.md +++ b/FAQ.md @@ -31,7 +31,7 @@ In the meantime you could try: In general, yes: it is a good idea to stay up-to-date. -If you have a version older than 2.38.1, it is *highly* advisable to upgrade. A couple of Git versions came with important fixes to security-relevant vulnerabilities: 2.38.1, 2.37.1, 2.36.0, 2.35.3, 2.35.3, 2.30.2, 2.30.0(2), 2.29.2(3), 2.29.2(2), 2.26.1, 2.24.1(2), 2.17.1(2), 2.14.1, 2.7.4, 2.7.0, 2.6.1, 2.5.2, 1.9.5-preview20150319, and 1.9.5-preview20141217. +If you have a version older than 2.39.1, it is *highly* advisable to upgrade. A couple of Git versions came with important fixes to security-relevant vulnerabilities: 2.39.1, 2.38.1, 2.37.1, 2.36.0, 2.35.3, 2.35.3, 2.30.2, 2.30.0(2), 2.29.2(3), 2.29.2(2), 2.26.1, 2.24.1(2), 2.17.1(2), 2.14.1, 2.7.4, 2.7.0, 2.6.1, 2.5.2, 1.9.5-preview20150319, and 1.9.5-preview20141217. ## What is the release cadence of Git for Windows? From c98e0d717b3c91e9b68fabf823a0d04719ac4787 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Tue, 24 Jan 2023 11:12:07 +0100 Subject: [PATCH 550/591] Replace `git-extra` with `mingw-w64-git-extra` --- Making-an-installer.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/Making-an-installer.md b/Making-an-installer.md index 5e768c67d95eb2..c4565914141859 100644 --- a/Making-an-installer.md +++ b/Making-an-installer.md @@ -53,15 +53,15 @@ where `` is the Git version (please note that the `` cannot co # Why is this installer so much larger than the official installer? -Short version: you will need to run `make strip` in `/usr/src/git` before `make install`, and you will also need to run to call `pacman -S git-extra` afterwards. +Short version: you will need to run `make strip` in `/usr/src/git` before `make install`, and you will also need to run to call `pacman -S mingw-w64-x86_64-git-extra` afterwards (replace `x86_64` with `i686` for 32-bit builds and with `clang-aarch64` for Windows/ARM64 builds). ## Why `make strip`? The `make strip` command removes the debug information from the `.exe` files. That is not quite the same as the official release process does: it calls `cv2pdb` which splits out the debug information from the `.exe` files into separate `.pdb` files, but that processing is not defined in `/usr/src/git/Makefile`, but instead in `/usr/src/MINGW-packages/mingw-w64-git/PKGBUILD`. -## Why `pacman -S git-extra`? +## Why `pacman -S mingw-w64-x86_64-git-extra`? -The `pacman -S git-extra` part is defined elsewhere yet: in `/usr/src/build-extra/please.sh`. Its purpose is to replace many hardlinked copies in `/mingw64/libexec/git-core/git-*.exe` with what Git for Windows calls the "Git wrapper": a small executable that does nothing else but call `git.exe` with the appropriate subcommand name. +The `pacman -S mingw-w64-x86_64-git-extra` part is defined elsewhere yet: in `/usr/src/build-extra/please.sh`. Its purpose is to replace many hardlinked copies in `/mingw64/libexec/git-core/git-*.exe` with what Git for Windows calls the "Git wrapper": a small executable that does nothing else but call `git.exe` with the appropriate subcommand name. You see, many "built-in" commands are implemented right there in `git.exe`, with no need to actually execute anything else. For example, when you call `git show`, the show part is executed inside `git.exe` itself. From 7147a1223183facba46e22cf5e4e68cb4cd5a08b Mon Sep 17 00:00:00 2001 From: Derrick Stolee Date: Tue, 14 Feb 2023 13:20:01 -0500 Subject: [PATCH 551/591] Updated FAQ (markdown) --- FAQ.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/FAQ.md b/FAQ.md index 92d9e08534d47f..e260e1e114cb6b 100644 --- a/FAQ.md +++ b/FAQ.md @@ -31,7 +31,7 @@ In the meantime you could try: In general, yes: it is a good idea to stay up-to-date. -If you have a version older than 2.39.1, it is *highly* advisable to upgrade. A couple of Git versions came with important fixes to security-relevant vulnerabilities: 2.39.1, 2.38.1, 2.37.1, 2.36.0, 2.35.3, 2.35.3, 2.30.2, 2.30.0(2), 2.29.2(3), 2.29.2(2), 2.26.1, 2.24.1(2), 2.17.1(2), 2.14.1, 2.7.4, 2.7.0, 2.6.1, 2.5.2, 1.9.5-preview20150319, and 1.9.5-preview20141217. +If you have a version older than 2.39.2, it is *highly* advisable to upgrade. A couple of Git versions came with important fixes to security-relevant vulnerabilities: 2.39.2, 2.39.1, 2.38.1, 2.37.1, 2.36.0, 2.35.3, 2.35.3, 2.30.2, 2.30.0(2), 2.29.2(3), 2.29.2(2), 2.26.1, 2.24.1(2), 2.17.1(2), 2.14.1, 2.7.4, 2.7.0, 2.6.1, 2.5.2, 1.9.5-preview20150319, and 1.9.5-preview20141217. ## What is the release cadence of Git for Windows? From 21bbbe4d56c9d5dbff1a29df9f2a14ddde2f5141 Mon Sep 17 00:00:00 2001 From: Davy Landman Date: Tue, 14 Mar 2023 17:48:15 +0100 Subject: [PATCH 552/591] Added more fat warnings. --- Install-inside-MSYS2-proper.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index 36c106d9fdadcc..e096d8b3fedb22 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -4,6 +4,8 @@ Git for Windows being based on MSYS2, it's possible to install the `mingw-w64-gi This guide assumes you are comfortable using the command line and you are willing to completely re-install your MSYS2 if something goes wrong. You can contact @Elieux for advice in the `git-for-windows/git` Gitter room or through the contact channels for MSYS2. Please don't file issues with Git for Windows installed this way until you verify them in an official Git for Windows distribution. +**note, current package collisions break https-remotes. So if you need them, this method is as-of-now, not suited for you. There is no ETA for a fix, if you would like to contribute and have experience with pacman packages & openssl, please come gitter** + #### The steps From f713029e4fc2317603c93cad254bedb12b168320 Mon Sep 17 00:00:00 2001 From: Davy Landman Date: Tue, 14 Mar 2023 18:02:40 +0100 Subject: [PATCH 553/591] Updated Install inside MSYS2 proper (markdown) --- Install-inside-MSYS2-proper.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index e096d8b3fedb22..0c7b17f6d6209a 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -4,7 +4,7 @@ Git for Windows being based on MSYS2, it's possible to install the `mingw-w64-gi This guide assumes you are comfortable using the command line and you are willing to completely re-install your MSYS2 if something goes wrong. You can contact @Elieux for advice in the `git-for-windows/git` Gitter room or through the contact channels for MSYS2. Please don't file issues with Git for Windows installed this way until you verify them in an official Git for Windows distribution. -**note, current package collisions break https-remotes. So if you need them, this method is as-of-now, not suited for you. There is no ETA for a fix, if you would like to contribute and have experience with pacman packages & openssl, please come gitter** +**Warning: an openssl package-collision breaks https-remotes. So if you have repositories that pull from https: this method is -- as-of-now -- not suited for you. There is no ETA for a fix, if you would like to contribute and have experience with pacman packages & openssl, please come to our gitter channel.** #### The steps From 90f9837bc14409bf055b452c1f14130331b18ff7 Mon Sep 17 00:00:00 2001 From: David Macek Date: Wed, 15 Mar 2023 09:58:23 +0100 Subject: [PATCH 554/591] Mention steps to fix DLL issues; merge all notes into one section as the topics overlap a lot --- Install-inside-MSYS2-proper.md | 16 ++++++---------- 1 file changed, 6 insertions(+), 10 deletions(-) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index 0c7b17f6d6209a..5401a6173d5996 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -4,8 +4,6 @@ Git for Windows being based on MSYS2, it's possible to install the `mingw-w64-gi This guide assumes you are comfortable using the command line and you are willing to completely re-install your MSYS2 if something goes wrong. You can contact @Elieux for advice in the `git-for-windows/git` Gitter room or through the contact channels for MSYS2. Please don't file issues with Git for Windows installed this way until you verify them in an official Git for Windows distribution. -**Warning: an openssl package-collision breaks https-remotes. So if you have repositories that pull from https: this method is -- as-of-now -- not suited for you. There is no ETA for a fix, if you would like to contribute and have experience with pacman packages & openssl, please come to our gitter channel.** - #### The steps @@ -57,24 +55,22 @@ Here are the steps to install the 64-bit version of Git for Windows to be run in Now you can close the current shell and open a MINGW64 shell (`msys2_shell.cmd -mingw64`) to check that everything went well. Run `git --version` and it should output something like `git version 2.31.0.windows.1` (or newer). + +#### Enhancements, modifications, troubleshooting + If you want to run Git from outside the shells, add `C:\msys64\cmd` to your `PATH`, e.g. by using *Edit environment variables for your account* from the Start menu. It has to come before any other entry pointing inside your MSYS2 installation. If you have installed your MSYS2 into a different directory, correct the path accordingly. -To integrate with the Windows Credential Manager, install the package `git-credential-manager`. +To integrate with the Windows Credential Manager, install the package `mingw-w64-x86_64-git-credential-manager`. To be able to view the git man pages when invoking help with `git help X` or `git X --help` (in addition to `man git-X`), add the line `export MSYS2_ENV_CONV_EXCL=MANPATH` to your shell configuration, and set the man pages as default help format with `git config --global help.format man` (or append `-m` to the git help invocation). -#### Troubleshooting - If you encounter error "*error: wrong number of arguments, should be from 1 to 2*" with `git add -p`, set `add.interactive.useBuiltin` to `true` in Git's configuration. - -#### Notes +If you encounter DLL errors (*The code execution cannot proceed because libsomething.dll was not found.*), this is most likely an incompatibility between the DLL versions from Git for Windows and upstream MSYS2. Usually this is caused by cURL, GnuTLS and OpenSSL. Replacing the packages with the ones from upstream seems to work best, but no guarantees for what that actually does with Git: `pacman -S mingw64/mingw-w64-x86_64-curl mingw-w64-x86_64-gnutls mingw64/mingw-w64-x86_64-openssl` Git for Windows carries an `msys2-runtime` different from upstream MSYS2, see [issue #284](https://github.com/git-for-windows/git/issues/284) for more details. You can run into some rare issues with programs other than Git due to this. It's possible to keep the stock MSYS2 runtime by moving the `msys` repository above the `git-for-windows` repository in `/etc/pacman.conf`. There are known issues with Git in that case, although not common. -Git for Windows also patches some other packages like cURL and OpenSSL. It unfortunately sometimes causes some packages to be behind in terms of their version, but keeping the upstream packages would most probably lead to a severely broken Git. - -The `mingw-w64-git-extra` package modifies the MSYS2 environment heavily (sometimes in ways that are tedious to undo). The package can be skipped if you want to keep your MSYS2 pristine. As of this writing, the package: +The `mingw-w64-x86_64-git-extra` package modifies the MSYS2 installation heavily (sometimes in ways that are tedious to undo). The package can be skipped if you want to keep your MSYS2 pristine. As of this writing, the package: - brings the `git-for-windows-keyring` package as its dependency, but you can install it manually - adds the `sdk` command intended for developing Git for Windows From 6ad670478f1fbdc38d77f57056e2fe9cfbef4524 Mon Sep 17 00:00:00 2001 From: David Macek Date: Wed, 15 Mar 2023 10:00:19 +0100 Subject: [PATCH 555/591] Note that the guide should be read completely first --- Install-inside-MSYS2-proper.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index 5401a6173d5996..72d7214bec7b1d 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -1,6 +1,6 @@ # **Please note that this scenario is not officially supported by Git for Windows** -Git for Windows being based on MSYS2, it's possible to install the `mingw-w64-git` package into an existing MSYS2 installation. That means that if you are already using MSYS2 on your computer, you can use Git for Windows without running the full installer or using the portable version. There are some caveats for going this way, details below. +Git for Windows being based on MSYS2, it's possible to install the `mingw-w64-git` package into an existing MSYS2 installation. That means that if you are already using MSYS2 on your computer, you can use Git for Windows without running the full installer or using the portable version. There are some caveats for going this way, details below. Reading the whole guide before starting is recommended. This guide assumes you are comfortable using the command line and you are willing to completely re-install your MSYS2 if something goes wrong. You can contact @Elieux for advice in the `git-for-windows/git` Gitter room or through the contact channels for MSYS2. Please don't file issues with Git for Windows installed this way until you verify them in an official Git for Windows distribution. From 6f5dd321283ebc1855c50c3c9b44c221d4110268 Mon Sep 17 00:00:00 2001 From: David Macek Date: Mon, 3 Apr 2023 14:54:03 +0200 Subject: [PATCH 556/591] Add missing mingw64/ --- Install-inside-MSYS2-proper.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Install-inside-MSYS2-proper.md b/Install-inside-MSYS2-proper.md index 72d7214bec7b1d..ae5efb876bd515 100644 --- a/Install-inside-MSYS2-proper.md +++ b/Install-inside-MSYS2-proper.md @@ -66,7 +66,7 @@ To be able to view the git man pages when invoking help with `git help X` or `gi If you encounter error "*error: wrong number of arguments, should be from 1 to 2*" with `git add -p`, set `add.interactive.useBuiltin` to `true` in Git's configuration. -If you encounter DLL errors (*The code execution cannot proceed because libsomething.dll was not found.*), this is most likely an incompatibility between the DLL versions from Git for Windows and upstream MSYS2. Usually this is caused by cURL, GnuTLS and OpenSSL. Replacing the packages with the ones from upstream seems to work best, but no guarantees for what that actually does with Git: `pacman -S mingw64/mingw-w64-x86_64-curl mingw-w64-x86_64-gnutls mingw64/mingw-w64-x86_64-openssl` +If you encounter DLL errors (*The code execution cannot proceed because libsomething.dll was not found.*), this is most likely an incompatibility between the DLL versions from Git for Windows and upstream MSYS2. Usually this is caused by cURL, GnuTLS and OpenSSL. Replacing the packages with the ones from upstream seems to work best, but no guarantees for what that actually does with Git: `pacman -S mingw64/mingw-w64-x86_64-curl mingw64/mingw-w64-x86_64-gnutls mingw64/mingw-w64-x86_64-openssl` Git for Windows carries an `msys2-runtime` different from upstream MSYS2, see [issue #284](https://github.com/git-for-windows/git/issues/284) for more details. You can run into some rare issues with programs other than Git due to this. It's possible to keep the stock MSYS2 runtime by moving the `msys` repository above the `git-for-windows` repository in `/etc/pacman.conf`. There are known issues with Git in that case, although not common. From 61e96a43aff328aa6d6c58ba5eca6d0c446dce58 Mon Sep 17 00:00:00 2001 From: Victoria Dye Date: Tue, 25 Apr 2023 10:18:00 -0700 Subject: [PATCH 557/591] Add recommendation to upgrade to security release v2.40.1 --- FAQ.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/FAQ.md b/FAQ.md index e260e1e114cb6b..ddb5e65d152086 100644 --- a/FAQ.md +++ b/FAQ.md @@ -31,7 +31,7 @@ In the meantime you could try: In general, yes: it is a good idea to stay up-to-date. -If you have a version older than 2.39.2, it is *highly* advisable to upgrade. A couple of Git versions came with important fixes to security-relevant vulnerabilities: 2.39.2, 2.39.1, 2.38.1, 2.37.1, 2.36.0, 2.35.3, 2.35.3, 2.30.2, 2.30.0(2), 2.29.2(3), 2.29.2(2), 2.26.1, 2.24.1(2), 2.17.1(2), 2.14.1, 2.7.4, 2.7.0, 2.6.1, 2.5.2, 1.9.5-preview20150319, and 1.9.5-preview20141217. +If you have a version older than 2.40.1, it is *highly* advisable to upgrade. A couple of Git versions came with important fixes to security-relevant vulnerabilities: 2.40.1, 2.39.2, 2.39.1, 2.38.1, 2.37.1, 2.36.0, 2.35.3, 2.35.3, 2.30.2, 2.30.0(2), 2.29.2(3), 2.29.2(2), 2.26.1, 2.24.1(2), 2.17.1(2), 2.14.1, 2.7.4, 2.7.0, 2.6.1, 2.5.2, 1.9.5-preview20150319, and 1.9.5-preview20141217. ## What is the release cadence of Git for Windows? From af14829e02c7334bbeba9bbdafbd8934174409b8 Mon Sep 17 00:00:00 2001 From: "wyt@nilnul" Date: Sat, 24 Jun 2023 14:59:40 +0800 Subject: [PATCH 558/591] file path limit consistent with https://github.com/git-for-windows/git/wiki/Git-cannot-create-a-file-or-directory-with-a-long-path --- FAQ.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/FAQ.md b/FAQ.md index ddb5e65d152086..b622000cec0a92 100644 --- a/FAQ.md +++ b/FAQ.md @@ -84,7 +84,7 @@ There are several methods for working around these problems: * Install and use [ConEmu](https://conemu.github.io/). ## I get errors trying to check out files with long path names. -Windows file paths are by default limited to 255 characters. Some repositories may have committed files which contain paths longer than the limit. By default, *Git for Windows* does not support long paths, and will print errors when trying to perform any operation on a long file name. Set the configuration property `core.longpaths` to true to allow certain Git operations to properly handle these files. See [this wiki page](https://github.com/git-for-windows/git/wiki/Git-cannot-create-a-file-or-directory-with-a-long-path) for more information. +Windows file paths are by default limited to 260 characters. Some repositories may have committed files which contain paths longer than the limit. By default, *Git for Windows* does not support long paths, and will print errors when trying to perform any operation on a long file name. Set the configuration property `core.longpaths` to true to allow certain Git operations to properly handle these files. See [this wiki page](https://github.com/git-for-windows/git/wiki/Git-cannot-create-a-file-or-directory-with-a-long-path) for more information. ## The installed files are duplicated and look massive - Why? All the apparent copies are simply hard links - see Issue 1997 [Use symbolic links for libexec](https://github.com/git-for-windows/git/issues/1997) for more details. From 3caea0a465e00e31187be3afb6491f6b750bb12d Mon Sep 17 00:00:00 2001 From: Nikolas Grottendieck Date: Tue, 17 Oct 2023 21:56:11 +0200 Subject: [PATCH 559/591] Make silent or unattended installation guide more comprehensive based on https://github.com/git-for-windows/git/issues/4630 --- Silent-or-Unattended-Installation.md | 67 ++++++++++++++++++++++++---- 1 file changed, 59 insertions(+), 8 deletions(-) diff --git a/Silent-or-Unattended-Installation.md b/Silent-or-Unattended-Installation.md index 7ce1dc5eaa9147..cdd2b6458cb22b 100644 --- a/Silent-or-Unattended-Installation.md +++ b/Silent-or-Unattended-Installation.md @@ -1,31 +1,82 @@ +## Using Command-Line Options + It is possible to install Git for Windows silently using the following flags when called from a command-line prompt: + ``` Git--.exe /VERYSILENT /NORESTART /NOCANCEL /SP- /CLOSEAPPLICATIONS /RESTARTAPPLICATIONS /COMPONENTS="icons,ext\reg\shellhere,assoc,assoc_sh" ``` -An example of this is +## Using Installer Options From a File + +You can also load install parameters from a file with `/LOADINF="filename"`, and you can record parameters to a file using `/SAVEINF="filename"`. + +Example for saving selected options to a file: + ``` -Git-2.12.2.2-64-bit.exe /VERYSILENT /NORESTART /NOCANCEL /SP- /CLOSEAPPLICATIONS /RESTARTAPPLICATIONS /COMPONENTS="icons,ext\reg\shellhere,assoc,assoc_sh" +Git--.exe /SAVEINF=git_options.ini ``` -You can find all of the possible flags to use by calling the installer with the `/?` flag (for the options supported by InnoSetup out of the box), and by inspecting the [`install.iss` file](https://github.com/git-for-windows/build-extra/blob/HEAD/installer/install.iss) (for custom options added only to Git for Windows' installer). +Example reusing that previously created file to silently install Git in unattended mode: -You can also load install parameters from a file with `/LOADINF="filename"`, and you can record parameters to a file using `/SAVEINF="filename"`. +``` +Git--.exe /VERYSILENT /NORESTART /NOCANCEL /LOADINF=git_options.ini +``` An example of a parameter file is: -``` +```ini [Setup] Lang=default Dir=C:\Program Files\Git Group=Git NoIcons=0 SetupType=default -Components= +Components=gitlfs,assoc,assoc_sh,windowsterminal Tasks= +EditorOption=VIM +CustomEditorPath= +DefaultBranchOption=main PathOption=Cmd SSHOption=OpenSSH -CRLFOption=CRLFAlways +TortoiseOption=false +CURLOption=WinSSL +CRLFOption=CRLFCommitAsIs +BashTerminalOption=MinTTY +GitPullBehaviorOption=Merge +UseCredentialManager=Enabled +PerformanceTweaksFSCache=Enabled +EnableSymlinks=Disabled +EnablePseudoConsoleSupport=Disabled +EnableFSMonitor=Disabled ``` -More information on commandline parameters can be found in [InnoSetup's documentation](http://www.jrsoftware.org/ishelp/index.php?topic=setupcmdline). \ No newline at end of file +## Installer Options + +You can find all of the possible flags to use by calling the installer with the `/?` flag (for the options supported by [InnoSetup](http://www.jrsoftware.org/ishelp/index.php?topic=setupcmdline) out of the box), and by inspecting the [`install.iss` file](https://github.com/git-for-windows/build-extra/blob/HEAD/installer/install.iss) (for custom options added only to Git for Windows' installer). + +### Custom Installer Options + +A list of installer custom options as of Git for Windows v2.42.0.windows.2 is below: + +| Key | Values | Default | Remark | +| ---------------------------------- | -------| ------- | ------ | +| EditorOption | Nano, VIM, Notepad++, VisualStudioCode, VisualStudioCodeInsiders, SublimeText, Atom, VSCodium, Notepad, Wordpad, CustomEditor | VIM | | +| CustomEditorPath | | | Path and options for custom text editor (only in combination with EditorOption=CustomEditor) | +| DefaultBranchOption | | | Default branch name | +| PathOption | BashOnly, Cmd, CmdTools | Cmd | | +| SSHOption | OpenSSH, ExternalOpenSSH, Plink | OpenSSH | | +| TortoiseOption | true, false | false | Only in combination with SSHOption=Plink | +| CurlOption | OpenSSL, WinSSL | OpenSSL | | +| CRLFOption | LFOnly, CRLFAlways, CRLFCommitAsIs | CRLFAlways | | +| BashTerminalOption | MinTTY, ConHost | MinTTY | | +| GitPullBehaviorOption | Merge, Rebase, FFOnly | Merge | | +| UseCredentialManager | Enabled, Disabled, Core | Enabled | Core does exactly the same as Enabled and exists for historical reasons | +| PerformanceTweaksFSCache | Enabled, Disabled | Enabled | | +| EnableSymlinks | Auto, Enabled, Disabled | Auto | | +| AddmandatoryASLRsecurityexceptions | Auto, Enabled, Disabled | Auto | | +| EnableBuiltinDifftool | Auto, Enabled, Disabled | Auto | | +| EnableBuiltinRebase | Auto, Enabled, Disabled | Auto | | +| EnableBuiltinStash | Auto, Enabled, Disabled | Auto | | +| EnableBuiltinInteractiveAdd | Auto, Enabled, Disabled | Auto | | +| EnablePseudoConsoleSupport | Auto, Enabled, Disabled | Auto | | +| EnableFSMonitor | Auto, Enabled, Disabled | Auto | | From d45329ebcfcd493442a586de3eaec1f3d80b7069 Mon Sep 17 00:00:00 2001 From: Nikolas Grottendieck Date: Tue, 17 Oct 2023 21:57:17 +0200 Subject: [PATCH 560/591] Improve wording for saving options to file --- Silent-or-Unattended-Installation.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Silent-or-Unattended-Installation.md b/Silent-or-Unattended-Installation.md index cdd2b6458cb22b..7694c27c2b69dc 100644 --- a/Silent-or-Unattended-Installation.md +++ b/Silent-or-Unattended-Installation.md @@ -10,7 +10,7 @@ Git--.exe /VERYSILENT /NORESTART /NOCANCEL /SP- /CLOSEAPPLICAT You can also load install parameters from a file with `/LOADINF="filename"`, and you can record parameters to a file using `/SAVEINF="filename"`. -Example for saving selected options to a file: +Example for saving selected options to a file during an interactive run started from the command-line: ``` Git--.exe /SAVEINF=git_options.ini From e65a12c85d0207d7b76ce7c6aac8406b6d7cfac4 Mon Sep 17 00:00:00 2001 From: Axel D Date: Fri, 3 Nov 2023 11:30:48 +0100 Subject: [PATCH 561/591] Code formatting added. --- Silent-or-Unattended-Installation.md | 44 ++++++++++++++-------------- 1 file changed, 22 insertions(+), 22 deletions(-) diff --git a/Silent-or-Unattended-Installation.md b/Silent-or-Unattended-Installation.md index 7694c27c2b69dc..f4e6bc99e40c69 100644 --- a/Silent-or-Unattended-Installation.md +++ b/Silent-or-Unattended-Installation.md @@ -58,25 +58,25 @@ You can find all of the possible flags to use by calling the installer with the A list of installer custom options as of Git for Windows v2.42.0.windows.2 is below: -| Key | Values | Default | Remark | -| ---------------------------------- | -------| ------- | ------ | -| EditorOption | Nano, VIM, Notepad++, VisualStudioCode, VisualStudioCodeInsiders, SublimeText, Atom, VSCodium, Notepad, Wordpad, CustomEditor | VIM | | -| CustomEditorPath | | | Path and options for custom text editor (only in combination with EditorOption=CustomEditor) | -| DefaultBranchOption | | | Default branch name | -| PathOption | BashOnly, Cmd, CmdTools | Cmd | | -| SSHOption | OpenSSH, ExternalOpenSSH, Plink | OpenSSH | | -| TortoiseOption | true, false | false | Only in combination with SSHOption=Plink | -| CurlOption | OpenSSL, WinSSL | OpenSSL | | -| CRLFOption | LFOnly, CRLFAlways, CRLFCommitAsIs | CRLFAlways | | -| BashTerminalOption | MinTTY, ConHost | MinTTY | | -| GitPullBehaviorOption | Merge, Rebase, FFOnly | Merge | | -| UseCredentialManager | Enabled, Disabled, Core | Enabled | Core does exactly the same as Enabled and exists for historical reasons | -| PerformanceTweaksFSCache | Enabled, Disabled | Enabled | | -| EnableSymlinks | Auto, Enabled, Disabled | Auto | | -| AddmandatoryASLRsecurityexceptions | Auto, Enabled, Disabled | Auto | | -| EnableBuiltinDifftool | Auto, Enabled, Disabled | Auto | | -| EnableBuiltinRebase | Auto, Enabled, Disabled | Auto | | -| EnableBuiltinStash | Auto, Enabled, Disabled | Auto | | -| EnableBuiltinInteractiveAdd | Auto, Enabled, Disabled | Auto | | -| EnablePseudoConsoleSupport | Auto, Enabled, Disabled | Auto | | -| EnableFSMonitor | Auto, Enabled, Disabled | Auto | | +| Key | Values | Default | Remark | +| - | - | - | - | +| `EditorOption` | `Nano`, `VIM`, `Notepad++`, `VisualStudioCode`, `VisualStudioCodeInsiders`, `SublimeText`, `Atom`, `VSCodium`, `Notepad`, `Wordpad`, `CustomEditor` | `VIM` | | +| `CustomEditorPath` | | | Path and options for custom text editor (only in combination with `EditorOption=CustomEditor`) | +| `DefaultBranchOption` | | | Default branch name | +| `PathOption` | `BashOnly`, `Cmd`, `CmdTools` | `Cmd` | | +| `SSHOption` | `OpenSSH`, `ExternalOpenSSH`, `Plink` | `OpenSSH` | | +| `TortoiseOption` | `true`, `false` | `false` | Only in combination with `SSHOption=Plink` | +| `CurlOption` | `OpenSSL`, `WinSSL` | `OpenSSL` | | +| `CRLFOption` | `LFOnly`, `CRLFAlways`, `CRLFCommitAsIs` | `CRLFAlways` | | +| `BashTerminalOption` | `MinTTY`, `ConHost` | `MinTTY` | | +| `GitPullBehaviorOption` | `Merge`, `Rebase`, `FFOnly` | `Merge` | | +| `UseCredentialManager` | `Enabled`, `Disabled`, `Core` | `Enabled` | `Core` does exactly the same as `Enabled` and exists for historical reasons | +| `PerformanceTweaksFSCache` | `Enabled`, `Disabled` | `Enabled` | | +| `EnableSymlinks` | `Auto`, `Enabled`, `Disabled` | `Auto` | | +| `AddmandatoryASLRsecurityexceptions` | `Auto`, `Enabled`, `Disabled` | `Auto` | | +| `EnableBuiltinDifftool` | `Auto`, `Enabled`, `Disabled` | `Auto` | | +| `EnableBuiltinRebase` | `Auto`, `Enabled`, `Disabled` | `Auto` | | +| `EnableBuiltinStash` | `Auto`, `Enabled`, `Disabled` | `Auto` | | +| `EnableBuiltinInteractiveAdd` | `Auto`, `Enabled`, `Disabled` | `Auto` | | +| `EnablePseudoConsoleSupport` | `Auto`, `Enabled`, `Disabled` | `Auto` | | +| `EnableFSMonitor` | `Auto`, `Enabled`, `Disabled` | `Auto` | | \ No newline at end of file From f7b3363319b81b641734faccfe13779793cdc576 Mon Sep 17 00:00:00 2001 From: Axel D Date: Fri, 3 Nov 2023 11:33:25 +0100 Subject: [PATCH 562/591] Updated Silent or Unattended Installation (markdown) --- Silent-or-Unattended-Installation.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Silent-or-Unattended-Installation.md b/Silent-or-Unattended-Installation.md index f4e6bc99e40c69..6a786578e5b264 100644 --- a/Silent-or-Unattended-Installation.md +++ b/Silent-or-Unattended-Installation.md @@ -58,7 +58,7 @@ You can find all of the possible flags to use by calling the installer with the A list of installer custom options as of Git for Windows v2.42.0.windows.2 is below: -| Key | Values | Default | Remark | +| Key | Values | Default | Remark | | - | - | - | - | | `EditorOption` | `Nano`, `VIM`, `Notepad++`, `VisualStudioCode`, `VisualStudioCodeInsiders`, `SublimeText`, `Atom`, `VSCodium`, `Notepad`, `Wordpad`, `CustomEditor` | `VIM` | | | `CustomEditorPath` | | | Path and options for custom text editor (only in combination with `EditorOption=CustomEditor`) | From a2a2e5b7dfe11f9c9331c7dd0b33bd5306e6ec16 Mon Sep 17 00:00:00 2001 From: Axel D Date: Fri, 3 Nov 2023 11:33:52 +0100 Subject: [PATCH 563/591] Updated Silent or Unattended Installation (markdown) --- Silent-or-Unattended-Installation.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Silent-or-Unattended-Installation.md b/Silent-or-Unattended-Installation.md index 6a786578e5b264..a92dd1ab0aea4c 100644 --- a/Silent-or-Unattended-Installation.md +++ b/Silent-or-Unattended-Installation.md @@ -58,7 +58,7 @@ You can find all of the possible flags to use by calling the installer with the A list of installer custom options as of Git for Windows v2.42.0.windows.2 is below: -| Key | Values | Default | Remark | +| Key |
Values | Default | Remark | | - | - | - | - | | `EditorOption` | `Nano`, `VIM`, `Notepad++`, `VisualStudioCode`, `VisualStudioCodeInsiders`, `SublimeText`, `Atom`, `VSCodium`, `Notepad`, `Wordpad`, `CustomEditor` | `VIM` | | | `CustomEditorPath` | | | Path and options for custom text editor (only in combination with `EditorOption=CustomEditor`) | From e7ff259a7311366a4bbf6ace8dbd5a25d39f23d6 Mon Sep 17 00:00:00 2001 From: Axel D Date: Fri, 3 Nov 2023 11:34:18 +0100 Subject: [PATCH 564/591] Updated Silent or Unattended Installation (markdown) --- Silent-or-Unattended-Installation.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Silent-or-Unattended-Installation.md b/Silent-or-Unattended-Installation.md index a92dd1ab0aea4c..aa7d3a6dea0660 100644 --- a/Silent-or-Unattended-Installation.md +++ b/Silent-or-Unattended-Installation.md @@ -58,7 +58,7 @@ You can find all of the possible flags to use by calling the installer with the A list of installer custom options as of Git for Windows v2.42.0.windows.2 is below: -| Key |
Values | Default | Remark | +| Key |
Values
| Default | Remark | | - | - | - | - | | `EditorOption` | `Nano`, `VIM`, `Notepad++`, `VisualStudioCode`, `VisualStudioCodeInsiders`, `SublimeText`, `Atom`, `VSCodium`, `Notepad`, `Wordpad`, `CustomEditor` | `VIM` | | | `CustomEditorPath` | | | Path and options for custom text editor (only in combination with `EditorOption=CustomEditor`) | From 62622ff27a56b61e46de32af5dbd289cef471278 Mon Sep 17 00:00:00 2001 From: Axel D Date: Fri, 3 Nov 2023 11:35:50 +0100 Subject: [PATCH 565/591] Updated Silent or Unattended Installation (markdown) --- Silent-or-Unattended-Installation.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Silent-or-Unattended-Installation.md b/Silent-or-Unattended-Installation.md index aa7d3a6dea0660..88e7e38b746181 100644 --- a/Silent-or-Unattended-Installation.md +++ b/Silent-or-Unattended-Installation.md @@ -58,7 +58,7 @@ You can find all of the possible flags to use by calling the installer with the A list of installer custom options as of Git for Windows v2.42.0.windows.2 is below: -| Key |
Values
| Default | Remark | +| Key |      Values      | Default | Remark | | - | - | - | - | | `EditorOption` | `Nano`, `VIM`, `Notepad++`, `VisualStudioCode`, `VisualStudioCodeInsiders`, `SublimeText`, `Atom`, `VSCodium`, `Notepad`, `Wordpad`, `CustomEditor` | `VIM` | | | `CustomEditorPath` | | | Path and options for custom text editor (only in combination with `EditorOption=CustomEditor`) | From f81a44b9670867f278a3f575b7d066d8ad309932 Mon Sep 17 00:00:00 2001 From: Axel D Date: Fri, 3 Nov 2023 11:36:39 +0100 Subject: [PATCH 566/591] Updated Silent or Unattended Installation (markdown) --- Silent-or-Unattended-Installation.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Silent-or-Unattended-Installation.md b/Silent-or-Unattended-Installation.md index 88e7e38b746181..4e933cabc38a69 100644 --- a/Silent-or-Unattended-Installation.md +++ b/Silent-or-Unattended-Installation.md @@ -58,7 +58,7 @@ You can find all of the possible flags to use by calling the installer with the A list of installer custom options as of Git for Windows v2.42.0.windows.2 is below: -| Key |      Values      | Default | Remark | +| Key |                     Values                     | Default | Remark | | - | - | - | - | | `EditorOption` | `Nano`, `VIM`, `Notepad++`, `VisualStudioCode`, `VisualStudioCodeInsiders`, `SublimeText`, `Atom`, `VSCodium`, `Notepad`, `Wordpad`, `CustomEditor` | `VIM` | | | `CustomEditorPath` | | | Path and options for custom text editor (only in combination with `EditorOption=CustomEditor`) | From d736982caba4714b94da2f67036305a9975a9cf2 Mon Sep 17 00:00:00 2001 From: Axel D Date: Fri, 3 Nov 2023 11:37:23 +0100 Subject: [PATCH 567/591] Updated Silent or Unattended Installation (markdown) --- Silent-or-Unattended-Installation.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Silent-or-Unattended-Installation.md b/Silent-or-Unattended-Installation.md index 4e933cabc38a69..deda9e8908546a 100644 --- a/Silent-or-Unattended-Installation.md +++ b/Silent-or-Unattended-Installation.md @@ -58,7 +58,7 @@ You can find all of the possible flags to use by calling the installer with the A list of installer custom options as of Git for Windows v2.42.0.windows.2 is below: -| Key |                     Values                     | Default | Remark | +| Key |                     Values                     | Default |                     Remark                     | | - | - | - | - | | `EditorOption` | `Nano`, `VIM`, `Notepad++`, `VisualStudioCode`, `VisualStudioCodeInsiders`, `SublimeText`, `Atom`, `VSCodium`, `Notepad`, `Wordpad`, `CustomEditor` | `VIM` | | | `CustomEditorPath` | | | Path and options for custom text editor (only in combination with `EditorOption=CustomEditor`) | From 45170bae3cc4462a1004bc6b8c74c8d951b2fb78 Mon Sep 17 00:00:00 2001 From: Axel D Date: Fri, 3 Nov 2023 11:38:05 +0100 Subject: [PATCH 568/591] Updated Silent or Unattended Installation (markdown) --- Silent-or-Unattended-Installation.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Silent-or-Unattended-Installation.md b/Silent-or-Unattended-Installation.md index deda9e8908546a..0e4e1a5ee4bb74 100644 --- a/Silent-or-Unattended-Installation.md +++ b/Silent-or-Unattended-Installation.md @@ -58,7 +58,7 @@ You can find all of the possible flags to use by calling the installer with the A list of installer custom options as of Git for Windows v2.42.0.windows.2 is below: -| Key |                     Values                     | Default |                     Remark                     | +| Key |                     Values                     | Default |                          Remark                          | | - | - | - | - | | `EditorOption` | `Nano`, `VIM`, `Notepad++`, `VisualStudioCode`, `VisualStudioCodeInsiders`, `SublimeText`, `Atom`, `VSCodium`, `Notepad`, `Wordpad`, `CustomEditor` | `VIM` | | | `CustomEditorPath` | | | Path and options for custom text editor (only in combination with `EditorOption=CustomEditor`) | From 61d258cd84992013c5d71efa13d1ffac3c35c1c0 Mon Sep 17 00:00:00 2001 From: Axel D Date: Fri, 3 Nov 2023 13:34:33 +0100 Subject: [PATCH 569/591] Page created explaining the mapping between Git Installer GUI settings panels and command line arguments. --- ...GUI-Settings-And-Command-Line-Arguments.md | 20 +++++++++++++++++++ 1 file changed, 20 insertions(+) create mode 100644 Mapping-between-Git-Installer-GUI-Settings-And-Command-Line-Arguments.md diff --git a/Mapping-between-Git-Installer-GUI-Settings-And-Command-Line-Arguments.md b/Mapping-between-Git-Installer-GUI-Settings-And-Command-Line-Arguments.md new file mode 100644 index 00000000000000..166e60fc234982 --- /dev/null +++ b/Mapping-between-Git-Installer-GUI-Settings-And-Command-Line-Arguments.md @@ -0,0 +1,20 @@ +The following table maps Git GUI Installation settings to corresponding Git Command Line Installation arguments: + +| Screenshot | Available Arguments (in sequence) | Example Arguments | +| - | - | - | +| ![Git 01](https://github.com/git-for-windows/git/assets/9283914/ca0ae5e8-77ed-4a46-ac4b-b8b2f29e1504) | `Components=`

  • `icons`
  • `ext\reg\shellhere`
  • `gitlfs`
  • `assoc`
  • `assoc_sh`
  • `windowsterminal`
  • `scalar`
| `Components=gitlfs,scalar` | +| ![Git 02](https://github.com/git-for-windows/git/assets/9283914/44547320-012f-4a14-9c20-657a67a45813) | `EditorOption=`

  • `Nano`
  • `VIM`
  • `Notepad++`
  • `VisualStudioCode`
  • `VisualStudioCodeInsiders`
  • `SublimeText`
  • `Atom`
  • `VSCodium`
  • `Notepad`
  • `Wordpad`
  • `CustomEditor`
| `EditorOption=VisualStudioCode` | +| ![Git 03](https://github.com/git-for-windows/git/assets/9283914/748ecec9-d460-4bb2-bcb7-63cf9f37c882) | `DefaultBranchOption=`

*{branch name}* | `DefaultBranchOption=main` | +| ![Git 04](https://github.com/git-for-windows/git/assets/9283914/7296a36f-416d-4ab6-9913-c83cfa6f2a06) | `PathOption=`

  • `BashOnly`
  • `Cmd`
  • `CmdTools`
| `PathOption=Cmd` | +| ![Git 05](https://github.com/git-for-windows/git/assets/9283914/ed274bde-ab0e-49d5-820e-3bd6fae6f873) | `SSHOption=`

  • `OpenSSH`
  • `ExternalOpenSSH`
  • `Plink`
| `SSHOption=ExternalOpenSSH` | +| ![Git 06](https://github.com/git-for-windows/git/assets/9283914/0b5711f9-d1ad-4c64-aae6-0629a0bda235) | `CurlOption=`

  • `OpenSSL`
  • `WinSSL`
| `CurlOption=WinSSL` | +| ![Git 07](https://github.com/git-for-windows/git/assets/9283914/d8d5b885-1c26-439b-9dab-ea855f0387ca) | `CRLFOption=`

  • `CRLFAlways`
  • `LFOnly`
  • `CRLFCommitAsIs`
| `CRLFOption=CRLFAlways` | +| ![Git 08](https://github.com/git-for-windows/git/assets/9283914/bb676934-eafb-4316-bbfd-877e6eb2b659) | `BashTerminalOption=`

  • `MinTTY`
  • `ConHost`
| `BashTerminalOption=ConHost` | +| ![Git 09](https://github.com/git-for-windows/git/assets/9283914/b802d077-650a-4f41-a87f-23e2ff412c66) | `GitPullBehaviorOption=`

  • `Merge`
  • `Rebase`
  • `FFOnly`
| `GitPullBehaviorOption=Merge` | +| ![Git 10](https://github.com/git-for-windows/git/assets/9283914/c556c3e1-f9bc-4462-b65e-3d87ff9aac1b) | `UseCredentialManager=`

  • `Enabled`
  • `Disabled`
  • `Core`
| `UseCredentialManager=Enabled` | +| ![Git 11](https://github.com/git-for-windows/git/assets/9283914/79864759-a5fa-499b-9a6b-94443b6a9253) | `PerformanceTweaksFSCache=`

  • `Enabled`
  • `Disabled`


`EnableSymlinks=`

  • `Auto`
  • `Enabled`
  • `Disabled`
| `PerformanceTweaksFSCache=Enabled`

`EnableSymlinks=Disabled` | +| ![Git 12](https://github.com/git-for-windows/git/assets/9283914/7bcdf2cb-2b6e-4a50-8f52-8b22e7df2a3c) | `EnablePseudoConsoleSupport=`

  • `Auto`
  • `Enabled`
  • `Disabled`


`EnableFSMonitor=`

  • `Auto`
  • `Enabled`
  • `Disabled`
| `EnablePseudoConsoleSupport=Disabled`

`EnableFSMonitor=Enabled` | + +
+ +The full list of command line arguments [can be found here](https://github.com/git-for-windows/git/wiki/Silent-or-Unattended-Installation). \ No newline at end of file From dd0393ecf6225eddb1b19602e0fdf64ef20cf4db Mon Sep 17 00:00:00 2001 From: Axel D Date: Fri, 3 Nov 2023 13:36:27 +0100 Subject: [PATCH 570/591] Updated Mapping between Git Installer GUI Settings And Command Line Arguments (markdown) --- ...GUI-Settings-And-Command-Line-Arguments.md | 24 +++++++++---------- 1 file changed, 12 insertions(+), 12 deletions(-) diff --git a/Mapping-between-Git-Installer-GUI-Settings-And-Command-Line-Arguments.md b/Mapping-between-Git-Installer-GUI-Settings-And-Command-Line-Arguments.md index 166e60fc234982..dbe6a72c897e81 100644 --- a/Mapping-between-Git-Installer-GUI-Settings-And-Command-Line-Arguments.md +++ b/Mapping-between-Git-Installer-GUI-Settings-And-Command-Line-Arguments.md @@ -2,18 +2,18 @@ The following table maps Git GUI Installation settings to corresponding Git Comm | Screenshot | Available Arguments (in sequence) | Example Arguments | | - | - | - | -| ![Git 01](https://github.com/git-for-windows/git/assets/9283914/ca0ae5e8-77ed-4a46-ac4b-b8b2f29e1504) | `Components=`

  • `icons`
  • `ext\reg\shellhere`
  • `gitlfs`
  • `assoc`
  • `assoc_sh`
  • `windowsterminal`
  • `scalar`
| `Components=gitlfs,scalar` | -| ![Git 02](https://github.com/git-for-windows/git/assets/9283914/44547320-012f-4a14-9c20-657a67a45813) | `EditorOption=`

  • `Nano`
  • `VIM`
  • `Notepad++`
  • `VisualStudioCode`
  • `VisualStudioCodeInsiders`
  • `SublimeText`
  • `Atom`
  • `VSCodium`
  • `Notepad`
  • `Wordpad`
  • `CustomEditor`
| `EditorOption=VisualStudioCode` | -| ![Git 03](https://github.com/git-for-windows/git/assets/9283914/748ecec9-d460-4bb2-bcb7-63cf9f37c882) | `DefaultBranchOption=`

*{branch name}* | `DefaultBranchOption=main` | -| ![Git 04](https://github.com/git-for-windows/git/assets/9283914/7296a36f-416d-4ab6-9913-c83cfa6f2a06) | `PathOption=`

  • `BashOnly`
  • `Cmd`
  • `CmdTools`
| `PathOption=Cmd` | -| ![Git 05](https://github.com/git-for-windows/git/assets/9283914/ed274bde-ab0e-49d5-820e-3bd6fae6f873) | `SSHOption=`

  • `OpenSSH`
  • `ExternalOpenSSH`
  • `Plink`
| `SSHOption=ExternalOpenSSH` | -| ![Git 06](https://github.com/git-for-windows/git/assets/9283914/0b5711f9-d1ad-4c64-aae6-0629a0bda235) | `CurlOption=`

  • `OpenSSL`
  • `WinSSL`
| `CurlOption=WinSSL` | -| ![Git 07](https://github.com/git-for-windows/git/assets/9283914/d8d5b885-1c26-439b-9dab-ea855f0387ca) | `CRLFOption=`

  • `CRLFAlways`
  • `LFOnly`
  • `CRLFCommitAsIs`
| `CRLFOption=CRLFAlways` | -| ![Git 08](https://github.com/git-for-windows/git/assets/9283914/bb676934-eafb-4316-bbfd-877e6eb2b659) | `BashTerminalOption=`

  • `MinTTY`
  • `ConHost`
| `BashTerminalOption=ConHost` | -| ![Git 09](https://github.com/git-for-windows/git/assets/9283914/b802d077-650a-4f41-a87f-23e2ff412c66) | `GitPullBehaviorOption=`

  • `Merge`
  • `Rebase`
  • `FFOnly`
| `GitPullBehaviorOption=Merge` | -| ![Git 10](https://github.com/git-for-windows/git/assets/9283914/c556c3e1-f9bc-4462-b65e-3d87ff9aac1b) | `UseCredentialManager=`

  • `Enabled`
  • `Disabled`
  • `Core`
| `UseCredentialManager=Enabled` | -| ![Git 11](https://github.com/git-for-windows/git/assets/9283914/79864759-a5fa-499b-9a6b-94443b6a9253) | `PerformanceTweaksFSCache=`

  • `Enabled`
  • `Disabled`


`EnableSymlinks=`

  • `Auto`
  • `Enabled`
  • `Disabled`
| `PerformanceTweaksFSCache=Enabled`

`EnableSymlinks=Disabled` | -| ![Git 12](https://github.com/git-for-windows/git/assets/9283914/7bcdf2cb-2b6e-4a50-8f52-8b22e7df2a3c) | `EnablePseudoConsoleSupport=`

  • `Auto`
  • `Enabled`
  • `Disabled`


`EnableFSMonitor=`

  • `Auto`
  • `Enabled`
  • `Disabled`
| `EnablePseudoConsoleSupport=Disabled`

`EnableFSMonitor=Enabled` | +| ![Git 01](https://github.com/git-for-windows/git/assets/9283914/ca0ae5e8-77ed-4a46-ac4b-b8b2f29e1504) |
`Components=`

  • `icons`
  • `ext\reg\shellhere`
  • `gitlfs`
  • `assoc`
  • `assoc_sh`
  • `windowsterminal`
  • `scalar`

| `Components=gitlfs,scalar` | +| ![Git 02](https://github.com/git-for-windows/git/assets/9283914/44547320-012f-4a14-9c20-657a67a45813) |
`EditorOption=`

  • `Nano`
  • `VIM`
  • `Notepad++`
  • `VisualStudioCode`
  • `VisualStudioCodeInsiders`
  • `SublimeText`
  • `Atom`
  • `VSCodium`
  • `Notepad`
  • `Wordpad`
  • `CustomEditor`

| `EditorOption=VisualStudioCode` | +| ![Git 03](https://github.com/git-for-windows/git/assets/9283914/748ecec9-d460-4bb2-bcb7-63cf9f37c882) |
`DefaultBranchOption=`

*{branch name}*
| `DefaultBranchOption=main` | +| ![Git 04](https://github.com/git-for-windows/git/assets/9283914/7296a36f-416d-4ab6-9913-c83cfa6f2a06) |
`PathOption=`

  • `BashOnly`
  • `Cmd`
  • `CmdTools`

| `PathOption=Cmd` | +| ![Git 05](https://github.com/git-for-windows/git/assets/9283914/ed274bde-ab0e-49d5-820e-3bd6fae6f873) |
`SSHOption=`

  • `OpenSSH`
  • `ExternalOpenSSH`
  • `Plink`

| `SSHOption=ExternalOpenSSH` | +| ![Git 06](https://github.com/git-for-windows/git/assets/9283914/0b5711f9-d1ad-4c64-aae6-0629a0bda235) |
`CurlOption=`

  • `OpenSSL`
  • `WinSSL`

| `CurlOption=WinSSL` | +| ![Git 07](https://github.com/git-for-windows/git/assets/9283914/d8d5b885-1c26-439b-9dab-ea855f0387ca) |
`CRLFOption=`

  • `CRLFAlways`
  • `LFOnly`
  • `CRLFCommitAsIs`

| `CRLFOption=CRLFAlways` | +| ![Git 08](https://github.com/git-for-windows/git/assets/9283914/bb676934-eafb-4316-bbfd-877e6eb2b659) |
`BashTerminalOption=`

  • `MinTTY`
  • `ConHost`

| `BashTerminalOption=ConHost` | +| ![Git 09](https://github.com/git-for-windows/git/assets/9283914/b802d077-650a-4f41-a87f-23e2ff412c66) |
`GitPullBehaviorOption=`

  • `Merge`
  • `Rebase`
  • `FFOnly`

| `GitPullBehaviorOption=Merge` | +| ![Git 10](https://github.com/git-for-windows/git/assets/9283914/c556c3e1-f9bc-4462-b65e-3d87ff9aac1b) |
`UseCredentialManager=`

  • `Enabled`
  • `Disabled`
  • `Core`

| `UseCredentialManager=Enabled` | +| ![Git 11](https://github.com/git-for-windows/git/assets/9283914/79864759-a5fa-499b-9a6b-94443b6a9253) |
`PerformanceTweaksFSCache=`

  • `Enabled`
  • `Disabled`


`EnableSymlinks=`

  • `Auto`
  • `Enabled`
  • `Disabled`

| `PerformanceTweaksFSCache=Enabled`

`EnableSymlinks=Disabled` | +| ![Git 12](https://github.com/git-for-windows/git/assets/9283914/7bcdf2cb-2b6e-4a50-8f52-8b22e7df2a3c) |
`EnablePseudoConsoleSupport=`

  • `Auto`
  • `Enabled`
  • `Disabled`


`EnableFSMonitor=`

  • `Auto`
  • `Enabled`
  • `Disabled`

| `EnablePseudoConsoleSupport=Disabled`

`EnableFSMonitor=Enabled` |
From c1e17b69da8a976887813455efe97593caf91fec Mon Sep 17 00:00:00 2001 From: Axel D Date: Fri, 3 Nov 2023 13:40:35 +0100 Subject: [PATCH 571/591] Updated Mapping between Git Installer GUI Settings And Command Line Arguments (markdown) --- ...een-Git-Installer-GUI-Settings-And-Command-Line-Arguments.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Mapping-between-Git-Installer-GUI-Settings-And-Command-Line-Arguments.md b/Mapping-between-Git-Installer-GUI-Settings-And-Command-Line-Arguments.md index dbe6a72c897e81..b741f27ac1f1c5 100644 --- a/Mapping-between-Git-Installer-GUI-Settings-And-Command-Line-Arguments.md +++ b/Mapping-between-Git-Installer-GUI-Settings-And-Command-Line-Arguments.md @@ -17,4 +17,4 @@ The following table maps Git GUI Installation settings to corresponding Git Comm
-The full list of command line arguments [can be found here](https://github.com/git-for-windows/git/wiki/Silent-or-Unattended-Installation). \ No newline at end of file +For a full list of command line arguments [see here](https://github.com/git-for-windows/git/wiki/Silent-or-Unattended-Installation). \ No newline at end of file From 894b91a0fedfe26c7209dcdb1b5c777d143f1f6f Mon Sep 17 00:00:00 2001 From: Axel D Date: Fri, 3 Nov 2023 13:41:08 +0100 Subject: [PATCH 572/591] Updated Mapping between Git Installer GUI Settings And Command Line Arguments (markdown) --- ...een-Git-Installer-GUI-Settings-And-Command-Line-Arguments.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Mapping-between-Git-Installer-GUI-Settings-And-Command-Line-Arguments.md b/Mapping-between-Git-Installer-GUI-Settings-And-Command-Line-Arguments.md index b741f27ac1f1c5..6d16f0f6aef923 100644 --- a/Mapping-between-Git-Installer-GUI-Settings-And-Command-Line-Arguments.md +++ b/Mapping-between-Git-Installer-GUI-Settings-And-Command-Line-Arguments.md @@ -17,4 +17,4 @@ The following table maps Git GUI Installation settings to corresponding Git Comm
-For a full list of command line arguments [see here](https://github.com/git-for-windows/git/wiki/Silent-or-Unattended-Installation). \ No newline at end of file +For a comprehensive list of Git for Windows Installer command line arguments [see here](https://github.com/git-for-windows/git/wiki/Silent-or-Unattended-Installation). \ No newline at end of file From fc7d946a6507281b3f5858f75e71a58b908ecc91 Mon Sep 17 00:00:00 2001 From: Axel D Date: Fri, 3 Nov 2023 13:42:58 +0100 Subject: [PATCH 573/591] Updated 0. Index (markdown) --- 0.-Index.md | 1 + 1 file changed, 1 insertion(+) diff --git a/0.-Index.md b/0.-Index.md index 7a5cea13e3c921..34bdfb58ed66f1 100644 --- a/0.-Index.md +++ b/0.-Index.md @@ -35,6 +35,7 @@ This is for the poor souls in corporate IE environments who can't expand the pag * [Running Git's regression tests](https://github.com/git-for-windows/git/wiki/Running-Git's-regression-tests) * [Setting your Core.Editor ( e.g. Notepad )](https://github.com/git-for-windows/git/wiki/Setting-your-Core.Editor-(-e.g.-Notepad-)) * [Silent or Unattended Installation](https://github.com/git-for-windows/git/wiki/Silent-or-Unattended-Installation) +* [Mapping between Git Installer GUI Settings And Command Line Arguments](https://github.com/git-for-windows/git/wiki/Mapping-between-Git-Installer-GUI-Settings-And-Command-Line-Arguments) * [Sourcetrail code viewer and linkage to Visual Studio, for Git](https://github.com/git-for-windows/git/wiki/Sourcetrail-code-viewer-and-linkage-to-Visual-Studio,-for-Git) * [Symbolic Links](https://github.com/git-for-windows/git/wiki/Symbolic-Links) * [Technical overview](https://github.com/git-for-windows/git/wiki/Technical-overview) From 42388faa09fc7a4e383ffb8b9726f399076c4ea9 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Fri, 3 Nov 2023 15:00:10 +0100 Subject: [PATCH 574/591] Make 0.Index alphabetically sorted again Like any good index, it has an inherent (alphabetical) order. Unfortunately, this was missed when a new item was added recently. Using my teutonic thoroughness, I set the order right again. Signed-off-by: Johannes Schindelin --- 0.-Index.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/0.-Index.md b/0.-Index.md index 34bdfb58ed66f1..498ba6aa5f2d8b 100644 --- a/0.-Index.md +++ b/0.-Index.md @@ -24,6 +24,7 @@ This is for the poor souls in corporate IE environments who can't expand the pag * [Issue reporting guidelines](https://github.com/git-for-windows/git/wiki/Issue-reporting-guidelines) * [Making a portable Git](https://github.com/git-for-windows/git/wiki/Making-a-portable-Git) * [Making an installer](https://github.com/git-for-windows/git/wiki/Making-an-installer) +* [Mapping between Git Installer GUI Settings And Command Line Arguments](https://github.com/git-for-windows/git/wiki/Mapping-between-Git-Installer-GUI-Settings-And-Command-Line-Arguments) * [Merge Conflicts Resolving and Remembering them](https://github.com/git-for-windows/git/wiki/Merge-Conflicts---Resolving-and-Remembering-them) * [MinGit is Git for Windows Applications](https://github.com/git-for-windows/git/wiki/MinGit) * [MSYS2 Notes](https://github.com/git-for-windows/git/wiki/MSYS2-Notes) @@ -35,7 +36,6 @@ This is for the poor souls in corporate IE environments who can't expand the pag * [Running Git's regression tests](https://github.com/git-for-windows/git/wiki/Running-Git's-regression-tests) * [Setting your Core.Editor ( e.g. Notepad )](https://github.com/git-for-windows/git/wiki/Setting-your-Core.Editor-(-e.g.-Notepad-)) * [Silent or Unattended Installation](https://github.com/git-for-windows/git/wiki/Silent-or-Unattended-Installation) -* [Mapping between Git Installer GUI Settings And Command Line Arguments](https://github.com/git-for-windows/git/wiki/Mapping-between-Git-Installer-GUI-Settings-And-Command-Line-Arguments) * [Sourcetrail code viewer and linkage to Visual Studio, for Git](https://github.com/git-for-windows/git/wiki/Sourcetrail-code-viewer-and-linkage-to-Visual-Studio,-for-Git) * [Symbolic Links](https://github.com/git-for-windows/git/wiki/Symbolic-Links) * [Technical overview](https://github.com/git-for-windows/git/wiki/Technical-overview) From f692f1c4f6cfecd7118d9e0845a498299c60adea Mon Sep 17 00:00:00 2001 From: Axel D Date: Mon, 6 Nov 2023 13:47:22 +0100 Subject: [PATCH 575/591] Updated Mapping between Git Installer GUI Settings And Command Line Arguments (markdown) --- ...een-Git-Installer-GUI-Settings-And-Command-Line-Arguments.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Mapping-between-Git-Installer-GUI-Settings-And-Command-Line-Arguments.md b/Mapping-between-Git-Installer-GUI-Settings-And-Command-Line-Arguments.md index 6d16f0f6aef923..c239635381feba 100644 --- a/Mapping-between-Git-Installer-GUI-Settings-And-Command-Line-Arguments.md +++ b/Mapping-between-Git-Installer-GUI-Settings-And-Command-Line-Arguments.md @@ -1,6 +1,6 @@ The following table maps Git GUI Installation settings to corresponding Git Command Line Installation arguments: -| Screenshot | Available Arguments (in sequence) | Example Arguments | +| Screenshot | Available Arguments
(in sequence) | Example Arguments | | - | - | - | | ![Git 01](https://github.com/git-for-windows/git/assets/9283914/ca0ae5e8-77ed-4a46-ac4b-b8b2f29e1504) |
`Components=`

  • `icons`
  • `ext\reg\shellhere`
  • `gitlfs`
  • `assoc`
  • `assoc_sh`
  • `windowsterminal`
  • `scalar`

| `Components=gitlfs,scalar` | | ![Git 02](https://github.com/git-for-windows/git/assets/9283914/44547320-012f-4a14-9c20-657a67a45813) |
`EditorOption=`

  • `Nano`
  • `VIM`
  • `Notepad++`
  • `VisualStudioCode`
  • `VisualStudioCodeInsiders`
  • `SublimeText`
  • `Atom`
  • `VSCodium`
  • `Notepad`
  • `Wordpad`
  • `CustomEditor`

| `EditorOption=VisualStudioCode` | From aed1d9a1e637798657db6557e91156dfbb21d25a Mon Sep 17 00:00:00 2001 From: Dom Slee Date: Sat, 11 Nov 2023 23:28:29 +1100 Subject: [PATCH 576/591] =?UTF-8?q?Add=20deprecation=20warning.=20It=20may?= =?UTF-8?q?=20help=20new=20people=20(like=20me)=20avoid=20looking=20for=20?= =?UTF-8?q?`git.sln`=20on=20the=20`vs/main`=20branch=20=F0=9F=91=8D?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- Compiling-Git-with-Visual-Studio.md | 3 +++ 1 file changed, 3 insertions(+) diff --git a/Compiling-Git-with-Visual-Studio.md b/Compiling-Git-with-Visual-Studio.md index a029b6bdb769c4..6445f734b8f6d8 100644 --- a/Compiling-Git-with-Visual-Studio.md +++ b/Compiling-Git-with-Visual-Studio.md @@ -2,6 +2,9 @@ Please note: this page describes how to compile Git's source code in Visual Stud # Checking out `vs/main` +> [!WARNING] +> The `vs/main` branch and `git.sln` is deprecated. The current approach is to open the `git` folder in VS directly, refer to the [README of the `vs/main` branch](https://github.com/git-for-windows/git/tree/vs/main). + Git's source code (and hence also Git for Windows' source code) is [usually built using GNU C and GNU Make in a Git for Windows SDK](https://github.com/git-for-windows/git/wiki/Building-Git). However, as of Git for Windows v2.11.0, a much more convenient way is available: by cloning https://github.com/git-for-windows/git and checking out the `vs/main` branch, you will automatically have project definitions ready to go with Visual Studio. From 0df663304bce986da6571cca48b34508d4823a11 Mon Sep 17 00:00:00 2001 From: Chandra Pratap Date: Sat, 16 Dec 2023 22:16:19 +0530 Subject: [PATCH 577/591] Redirect broken link to the correct one --- Home.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Home.md b/Home.md index feaa70a40d1209..ad4d98b4111da2 100644 --- a/Home.md +++ b/Home.md @@ -18,7 +18,7 @@ And yes, the idea is still the same as the original one: Update the _MSYS2_ setu Now, keep in mind that _MSYS2_ and Linux (The original target for _Git_'s distribution) are very different beasts. Their distributions might include packages that are built from the same source code (i.e. the `binutils`, `gcc` or `bash` package), but the runtime is very, very different: _MSYS2_'s runtime is a stripped-down, slightly modified _Cygwin_ runtime running on top of the Windows kernel, while Linux' runtime is the Linux kernel, running as a separate OS altogether. -So if you are missing some packages - feel free to start making one. This is Open Source, after all, so everybody interested and capable enough can contribute whatever they need to address their needs. And that includes you: you could imitate e.g. [a simple `PKGBUILD` file](https://github.com/msys2/MINGW-packages/blob/HEAD/mingw-w64-assimp-git/PKGBUILD) to build a new package e.g. `msmtp`, the component that _Git for Windows_ 1.x uses to support `sendemail`. Then open a Pull Request so that _Git for Windows_ can ship it. Our documentation will be helpful in that endeavor: [package-management](https://github.com/git-for-windows/git/wiki/Package-management), in particular [package-management#rebuild-packages](https://github.com/git-for-windows/git/wiki/Package-management#rebuild-packages). +So if you are missing some packages - feel free to start making one. This is Open Source, after all, so everybody interested and capable enough can contribute whatever they need to address their needs. And that includes you: you could imitate e.g. [a simple `PKGBUILD` file](https://github.com/msys2/MINGW-packages/blob/HEAD/mingw-w64-assimp/PKGBUILD) to build a new package e.g. `msmtp`, the component that _Git for Windows_ 1.x uses to support `sendemail`. Then open a Pull Request so that _Git for Windows_ can ship it. Our documentation will be helpful in that endeavor: [package-management](https://github.com/git-for-windows/git/wiki/Package-management), in particular [package-management#rebuild-packages](https://github.com/git-for-windows/git/wiki/Package-management#rebuild-packages). # Start documenting If you need inspiration what you could write about: document your common work flows. Write a tutorial how to start coding _Git for Windows_, how to run the test suite. Write a tutorial how to debug a failing test. Write about something you would have wished you had known about Git for Windows a long time ago. From 5753fb6fab9899da20f83b0574994021d5b2f6ac Mon Sep 17 00:00:00 2001 From: Multiservicios2023 <145180377+Multiservicios2023@users.noreply.github.com> Date: Wed, 10 Jan 2024 09:26:34 -0400 Subject: [PATCH 578/591] Created Dibujante_de_autocad (markdown) --- Dibujante_de_autocad.md | 1 + 1 file changed, 1 insertion(+) create mode 100644 Dibujante_de_autocad.md diff --git a/Dibujante_de_autocad.md b/Dibujante_de_autocad.md new file mode 100644 index 00000000000000..1e942bccac0ad3 --- /dev/null +++ b/Dibujante_de_autocad.md @@ -0,0 +1 @@ +servicio de dibujo en Autocad \ No newline at end of file From e278ce480b38830fe658b6690d5cabc56cf68e9e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Matthias=20A=C3=9Fhauer?= Date: Thu, 11 Jan 2024 17:06:18 +0100 Subject: [PATCH 579/591] Revert 0df663304bce986da6571cca48b34508d4823a11...5753fb6fab9899da20f83b0574994021d5b2f6ac --- Dibujante_de_autocad.md | 1 - 1 file changed, 1 deletion(-) delete mode 100644 Dibujante_de_autocad.md diff --git a/Dibujante_de_autocad.md b/Dibujante_de_autocad.md deleted file mode 100644 index 1e942bccac0ad3..00000000000000 --- a/Dibujante_de_autocad.md +++ /dev/null @@ -1 +0,0 @@ -servicio de dibujo en Autocad \ No newline at end of file From e477c936378f90cb57c09eba939e0e5af1a22de8 Mon Sep 17 00:00:00 2001 From: arisudesu Date: Mon, 15 Jan 2024 12:52:10 +0300 Subject: [PATCH 580/591] Fixed the link to getgit script --- ...-or-update-inside-MSYS2,-Cygwin-or-Git-for-windows-itself.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Install-or-update-inside-MSYS2,-Cygwin-or-Git-for-windows-itself.md b/Install-or-update-inside-MSYS2,-Cygwin-or-Git-for-windows-itself.md index 082f6784c1efb6..5c132923b198fb 100644 --- a/Install-or-update-inside-MSYS2,-Cygwin-or-Git-for-windows-itself.md +++ b/Install-or-update-inside-MSYS2,-Cygwin-or-Git-for-windows-itself.md @@ -4,7 +4,7 @@ Instead of configuring and installing Git for Windows using `pacman`, this guide ## How to -With the script `getgit` introduced by [git-for-windows/build-extra#261](https://github.com/git-for-windows/build-extra/pull/261), you can download and run the script or just run `curl https://raw.githubusercontent.com/git-for-windows/build-extra/HEAD/mingw-w64-git-extra/getgit | bash`. +With the script `getgit` introduced by [git-for-windows/build-extra#261](https://github.com/git-for-windows/build-extra/pull/261), you can download and run the script or just run `curl https://raw.githubusercontent.com/git-for-windows/build-extra/HEAD/git-extra/getgit | bash`. The script would gather information about the current system ( *Msys / Cygwin* ), bitness, version of an already existed Git for Windows, version of the latest released Git for Windows... and then forge a proper download URL targeting a proper version of the `PortableGit` installer. With all the information prepared, the script would download the installer and unpack it to `/tmp`. After that, all the necessary files will be copied to a proper place inside the ( *Msys's / Cygwin's* ) file system without touching any existing **non-git-for-windows-exclusive** files. From 0298fb627f6054db3fd20fb7a4af1f9d4328e123 Mon Sep 17 00:00:00 2001 From: Chirriz <158085764+Chirriz@users.noreply.github.com> Date: Thu, 1 Feb 2024 11:22:00 -0600 Subject: [PATCH 581/591] Updated _Footer (markdown) --- _Footer.md | 1 + 1 file changed, 1 insertion(+) diff --git a/_Footer.md b/_Footer.md index 472997268e045b..a476ab7954c2d3 100644 --- a/_Footer.md +++ b/_Footer.md @@ -1 +1,2 @@ This is the _Git for Windows_ wiki. See [how-to-participate](https://gitforwindows.org/governance-model.html). +mk**__**link /j principiantes c:\that-directory \ No newline at end of file From 3985d12eefabfb9e3618b93f2e9889a755ba853d Mon Sep 17 00:00:00 2001 From: Marijn Suijten Date: Thu, 1 Feb 2024 20:27:43 +0100 Subject: [PATCH 582/591] Revert ca955c8fd2837496fedc31d557ec0f983be99034...0298fb627f6054db3fd20fb7a4af1f9d4328e123 on _Footer --- _Footer.md | 1 - 1 file changed, 1 deletion(-) diff --git a/_Footer.md b/_Footer.md index a476ab7954c2d3..472997268e045b 100644 --- a/_Footer.md +++ b/_Footer.md @@ -1,2 +1 @@ This is the _Git for Windows_ wiki. See [how-to-participate](https://gitforwindows.org/governance-model.html). -mk**__**link /j principiantes c:\that-directory \ No newline at end of file From 9398d903fce4b34cffbcba2160a1ae33ddc6329f Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Sat, 10 Feb 2024 09:52:42 +0100 Subject: [PATCH 583/591] Adjust the documentation to how things are done now using the GitForWindowsHelper GitHub App --- Releasing-Git-for-Windows.md | 26 +++++++++++--------------- 1 file changed, 11 insertions(+), 15 deletions(-) diff --git a/Releasing-Git-for-Windows.md b/Releasing-Git-for-Windows.md index 03ba461876d18e..e37e59887ea2e0 100644 --- a/Releasing-Git-for-Windows.md +++ b/Releasing-Git-for-Windows.md @@ -89,32 +89,28 @@ When a new version is tagged in [upstream git](https://github.com/git/git), the - link the issue to the pull request created in the previous step - add the issue to the current "Next release" milestone ([example](https://github.com/git-for-windows/git/milestone/67)) -# Kicking off the "Git Artifacts" Azure Pipeline +# Kicking off the "Git Artifacts" automation -Direct your browser to https://dev.azure.com/git-for-windows/git/_build?definitionId=34&_a=summary and queue a new build ("Run pipeline") with the build variable `use.branch` set to something like `rebase-to-v2.27.0@https://github.com/dscho/git` and `Branch/tag` set to the PR's tip commit (e.g. `refs/pull/2645/head`). +Add a PR comment with [the slash command `/git-artifacts`](https://github.com/git-for-windows/gfw-helper-github-app?tab=readme-ov-file#git-artifacts). This will kick off several GitHub workflow runs in https://github.com/git-for-windows/git-for-windows-automation: one to create the tag and adjust the release notes, and then one each for every CPU architecture supported by Git for Windows generating: -That will pull down the PR branch of https://github.com/git-for-windows/git (technically, this is not necessary, because `use.branch` will make sure that the correct branch is used, but it makes the output nicer, as the Azure Pipeline will then show the correct commit in the summary), then look at the tags of https://github.com/git/git to determine the name of the new tag (read: the upcoming Git for Windows version), then fetch `main` of https://github.com/git-for-windows/build-extra, use the latter's `ReleaseNotes.md` to generate the message for the new tag, and then generate: - -- The 32-bit/64-bit installers -- The 32-bit/64-bit Portable Gits -- The 32-bit/64-bit `.tar.bz2` archives -- The 32-bit/64-bit MinGits -- The 32-bit/64-bit BusyBox-based MinGits -- The NuGet packages (both full and minimal version) - -and publish them as a build artifact. +- The installer +- The Portable Git +- The `.tar.bz2` archive +- The MinGit +- The BusyBox-based MinGit +- The NuGet packages (x86_64-only) # Verifying that the resulting installer works -The idea here is to download the `Git--64-bit.exe` artifact from the Pipeline, install it, and run through the "pre-flight check list" at https://github.com/git-for-windows/build-extra/blob/HEAD/installer/checklist.txt. +The idea here is to download the `Git--64-bit.exe` artifact from the workflow run, install it, and run through the "pre-flight check list" at https://github.com/git-for-windows/build-extra/blob/HEAD/installer/checklist.txt. # Kicking off the Azure Release Pipeline that publishes the release -This one is _really_ easy (as long as nothing is broken...): https://dev.azure.com/git-for-windows/git/_release?definitionId=1&_a=releases +This one is _really_ easy (as long as nothing is broken...): add a PR comment with [the `/release` slash command](https://github.com/git-for-windows/gfw-helper-github-app?tab=readme-ov-file#release). Note: The `pacman` upload always takes this long. -Sadly, things are broken a lot. In those cases, the logs have to be analyzed, and the Pipeline needs to be edited (when it asks whether you want to edit for this release only, do say that you want that), and the deployment has to be restarted. Examples for failures that happened in the past: +Sadly, things are broken a lot. In those cases, the logs have to be analyzed, and the GitHub workflow definition needs to be edited (on the `release` branch of https://github.com/git-for-windows/git-for-windows-automation), and the failing jobs of the workflow run have to be rerunExamples for failures that happened in the past: - Timeouts while uploading the GitHub Release. In that case, the partially-populated draft release has to be deleted manually (first delete the assets, or it won't delete the release), and then re-deploy. From 8c33978b61b5fcc7dfd2edb1cea8d260e9d4a86c Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Sat, 10 Feb 2024 11:25:08 +0100 Subject: [PATCH 584/591] Whoops, forgot to adjust some parts the the new lay of the land. --- Releasing-Git-for-Windows.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/Releasing-Git-for-Windows.md b/Releasing-Git-for-Windows.md index e37e59887ea2e0..c4370e0b0b13f5 100644 --- a/Releasing-Git-for-Windows.md +++ b/Releasing-Git-for-Windows.md @@ -3,9 +3,9 @@ The release process of Git for Windows is ever-evolving. For now, it consists of - Making sure that there are no unaddressed issues - Rebasing Git for Windows' patches - Opening a PR to kick off a PR build (and waiting for it to succeed) -- Kicking off the "Git Artifacts" Azure Pipeline +- Kicking off the `/git-artifacts` slash command - Verifying that the resulting installer works -- Kicking off the Azure Release Pipeline that publishes the release +- Kicking off the `/release` slash command that publishes the release - Pushing directly to `main` to close the PR and set the stage for the Azure Pipeline (at some stage during the `-rc` cycle) Note: the hardest part is traditonally preparing `-rc0` of every major release. @@ -104,7 +104,7 @@ Add a PR comment with [the slash command `/git-artifacts`](https://github.com/gi The idea here is to download the `Git--64-bit.exe` artifact from the workflow run, install it, and run through the "pre-flight check list" at https://github.com/git-for-windows/build-extra/blob/HEAD/installer/checklist.txt. -# Kicking off the Azure Release Pipeline that publishes the release +# Kicking off the `/release` slash command that publishes the release This one is _really_ easy (as long as nothing is broken...): add a PR comment with [the `/release` slash command](https://github.com/git-for-windows/gfw-helper-github-app?tab=readme-ov-file#release). From 6ffc9b132e445d74bfeb9c286eacb2db1d94e81c Mon Sep 17 00:00:00 2001 From: goyalyashpal Date: Tue, 27 Feb 2024 23:33:59 +0530 Subject: [PATCH 585/591] Bring the "Why, How, What" of the updates in continuity --- FAQ.md | 30 +++++++++++++++--------------- 1 file changed, 15 insertions(+), 15 deletions(-) diff --git a/FAQ.md b/FAQ.md index b622000cec0a92..6097d3f0d6e7de 100644 --- a/FAQ.md +++ b/FAQ.md @@ -33,21 +33,6 @@ In general, yes: it is a good idea to stay up-to-date. If you have a version older than 2.40.1, it is *highly* advisable to upgrade. A couple of Git versions came with important fixes to security-relevant vulnerabilities: 2.40.1, 2.39.2, 2.39.1, 2.38.1, 2.37.1, 2.36.0, 2.35.3, 2.35.3, 2.30.2, 2.30.0(2), 2.29.2(3), 2.29.2(2), 2.26.1, 2.24.1(2), 2.17.1(2), 2.14.1, 2.7.4, 2.7.0, 2.6.1, 2.5.2, 1.9.5-preview20150319, and 1.9.5-preview20141217. -## What is the release cadence of Git for Windows? - -Official Git for Windows versions mainly follow Git's release cycle: every 12 weeks or so, a new major Git version is released (see details here: https://tinyurl.com/gitCal). Typically, Git for Windows will follow suit within a day. - -Other than that, Git for Windows follows the *newest* Git version's maintenance releases (read: after Git for Windows v2.15.0 was released, no new Git for Windows v2.14.x version would be released). Indicators for imminent maintenance releases of Git are: - -- The Git maintainer sometimes talks about this in the preamble of the ["What's cooking in git.git" mails](https://public-inbox.org/git/?q=s%3A%22what%27s+cooking%22+AND+f%3Agitster%40pobox.com). -- The [`maint` in git.git](https://github.com/git/git/commits/maint) accumulates critical patches. - -Finally, Git for Windows is sometimes released in "out-of-band" versions, when critical fixes specific to Git for Windows necessitate it. These out-of-band versions are indicated by appending a `(2)` to the latest release (or `(3)`, `(4)`, etc). Examples for such out-of-band versions include: [Git for Windows v2.15.1(2)](https://github.com/git-for-windows/git/releases/tag/v2.15.1.windows.2) and [Git for Windows v2.16.1(4)](https://github.com/git-for-windows/git/releases/tag/v2.16.1.windows.4). - -## What is the relationship between *Git for Windows* and *msysGit*? - -*Git for Windows* used to be developed using the development environment called "msysGit", but roughly coinciding with Git 2.1, msysGit was superseded by a new development environment: the [Git for Windows SDK](https://github.com/git-for-windows/build-extra/releases). See [here](https://github.com/git-for-windows/git/wiki/Updating-your-SDK) to get a copy. - ## How do I update *Git for Windows* upon new releases? This depends on how you installed *Git for Windows*. The bundle installation requires you to download and install the new version. Any customizations you made will be kept as long as you did so in the appropriate configuration folders. @@ -70,6 +55,21 @@ The Git for Windows builds are not quite that frequent, but there are Snapshot b These often 'fix' (or attempt fixes) recent issues before a new formal release. Check their commit notes and links to issues to see if your problem is included. +## What is the release cadence of Git for Windows? + +Official Git for Windows versions mainly follow Git's release cycle: every 12 weeks or so, a new major Git version is released (see details here: https://tinyurl.com/gitCal). Typically, Git for Windows will follow suit within a day. + +Other than that, Git for Windows follows the *newest* Git version's maintenance releases (read: after Git for Windows v2.15.0 was released, no new Git for Windows v2.14.x version would be released). Indicators for imminent maintenance releases of Git are: + +- The Git maintainer sometimes talks about this in the preamble of the ["What's cooking in git.git" mails](https://public-inbox.org/git/?q=s%3A%22what%27s+cooking%22+AND+f%3Agitster%40pobox.com). +- The [`maint` in git.git](https://github.com/git/git/commits/maint) accumulates critical patches. + +Finally, Git for Windows is sometimes released in "out-of-band" versions, when critical fixes specific to Git for Windows necessitate it. These out-of-band versions are indicated by appending a `(2)` to the latest release (or `(3)`, `(4)`, etc). Examples for such out-of-band versions include: [Git for Windows v2.15.1(2)](https://github.com/git-for-windows/git/releases/tag/v2.15.1.windows.2) and [Git for Windows v2.16.1(4)](https://github.com/git-for-windows/git/releases/tag/v2.16.1.windows.4). + +## What is the relationship between *Git for Windows* and *msysGit*? + +*Git for Windows* used to be developed using the development environment called "msysGit", but roughly coinciding with Git 2.1, msysGit was superseded by a new development environment: the [Git for Windows SDK](https://github.com/git-for-windows/build-extra/releases). See [here](https://github.com/git-for-windows/git/wiki/Updating-your-SDK) to get a copy. + ## Some native console programs don't work when run from Git Bash. How to fix it? *Git for Windows* defaults to using [mintty](http://mintty.github.io/) terminal. Compared to default Windows console host, it provides normal multi-line cut&paste, working resizing, defaults to unicode font and avoids some bugs in the default console host. However it does not present itself as console to native applications (those *not* built with MSys or Cygwin), so in these applications: From 325fc9b01f16aac3fd32257f72be8bbc7c222723 Mon Sep 17 00:00:00 2001 From: SnoopdougyDoug <169108647+SnoopdougyDoug@users.noreply.github.com> Date: Sat, 11 May 2024 23:13:02 +0000 Subject: [PATCH 586/591] Destroyed FAQ (markdown) --- FAQ.md | 145 --------------------------------------------------------- 1 file changed, 145 deletions(-) delete mode 100644 FAQ.md diff --git a/FAQ.md b/FAQ.md deleted file mode 100644 index 6097d3f0d6e7de..00000000000000 --- a/FAQ.md +++ /dev/null @@ -1,145 +0,0 @@ -## Which versions of Windows are supported? - -Git for Windows currently works with all recent, commercially released x86 32 bit and 64 bit versions of Windows, starting with Windows 7 SP1. - -*** -NOTE: Git for Windows version [2.37.1](https://github.com/git-for-windows/git/releases/tag/v2.37.1.windows.1) was the last version supporting Windows Vista and Server 2008. -*** - -*** -NOTE: Git for Windows version [2.10.0](https://github.com/git-for-windows/git/releases/tag/v2.10.0.windows.1) was the last version supporting Windows XP and Server 2003. -*** - -Windows XP and Windows Server 2003 are long past their end of life, hence support for these versions was dropped from Git for Windows 2.10.1 and later. This limitation is inherited by Git's use of MSYS2, which in turn inherited it from [Cygwin](https://cygwin.com/ml/cygwin/2015-08/msg00446.html). - -More information here: [Git for Windows' prerequisites](https://gitforwindows.org/requirements.html). - -## Is there an MSI for installation via Group Policy? - -There is currently no MSI package; there is an exe installer and a portable package. You are welcome to contribute a Pull Request that packages a new installer. - -~There is an existing Pull Request in development and looking for testers, please try out https://github.com/robmen/gitsetup/issues/1 and give feedback.~ It's closed by now. Future development is happening [here](https://github.com/git-for-windows/build-extra/tree/HEAD/msi/). - -In the meantime you could try: - - * using the portable package - * deploying the exe installer with System Center Configuration Manager - * deploying the portable package via a script - * deploying the Chocolatey package via Puppet (or something similar) - -## Should I upgrade to a newer Git for Windows version? - -In general, yes: it is a good idea to stay up-to-date. - -If you have a version older than 2.40.1, it is *highly* advisable to upgrade. A couple of Git versions came with important fixes to security-relevant vulnerabilities: 2.40.1, 2.39.2, 2.39.1, 2.38.1, 2.37.1, 2.36.0, 2.35.3, 2.35.3, 2.30.2, 2.30.0(2), 2.29.2(3), 2.29.2(2), 2.26.1, 2.24.1(2), 2.17.1(2), 2.14.1, 2.7.4, 2.7.0, 2.6.1, 2.5.2, 1.9.5-preview20150319, and 1.9.5-preview20141217. - -## How do I update *Git for Windows* upon new releases? - -This depends on how you installed *Git for Windows*. The bundle installation requires you to download and install the new version. Any customizations you made will be kept as long as you did so in the appropriate configuration folders. - -*Git for Windows* comes with a tool to check for updates and offer to install them. Whether or not you enabled auto-updates during installation, you can manually run `git update-git-for-windows`. (For help, run `git update-git-for-windows -h`.) - -For advanced users working with the *Git for Windows* SDK `pacman` is available as a package manager. See [Package management](Package-management) - -## How do I check the release hash and release notes - -For hashes see https://github.com/git-for-windows/git/releases - -For (G4W) release notes see the [build-extra repo](https://github.com/git-for-windows/build-extra/blob/HEAD/ReleaseNotes.md), or the top level of your installation (e.g. [C:\Program Files\Git\ReleaseNotes.html](https://www.example.com/Program%20Files/Git/ReleaseNotes.html) - via manual browsing). - -For extracting 7z/zip archives see [page](https://github.com/git-for-windows/git/wiki/Zip-Archives---extracting-the-released-archives). - -## Are there 'Nightly' builds of the latest and greatest - -The Git for Windows builds are not quite that frequent, but there are Snapshot builds listed at https://wingit.blob.core.windows.net/files/index.html - -These often 'fix' (or attempt fixes) recent issues before a new formal release. Check their commit notes and links to issues to see if your problem is included. - -## What is the release cadence of Git for Windows? - -Official Git for Windows versions mainly follow Git's release cycle: every 12 weeks or so, a new major Git version is released (see details here: https://tinyurl.com/gitCal). Typically, Git for Windows will follow suit within a day. - -Other than that, Git for Windows follows the *newest* Git version's maintenance releases (read: after Git for Windows v2.15.0 was released, no new Git for Windows v2.14.x version would be released). Indicators for imminent maintenance releases of Git are: - -- The Git maintainer sometimes talks about this in the preamble of the ["What's cooking in git.git" mails](https://public-inbox.org/git/?q=s%3A%22what%27s+cooking%22+AND+f%3Agitster%40pobox.com). -- The [`maint` in git.git](https://github.com/git/git/commits/maint) accumulates critical patches. - -Finally, Git for Windows is sometimes released in "out-of-band" versions, when critical fixes specific to Git for Windows necessitate it. These out-of-band versions are indicated by appending a `(2)` to the latest release (or `(3)`, `(4)`, etc). Examples for such out-of-band versions include: [Git for Windows v2.15.1(2)](https://github.com/git-for-windows/git/releases/tag/v2.15.1.windows.2) and [Git for Windows v2.16.1(4)](https://github.com/git-for-windows/git/releases/tag/v2.16.1.windows.4). - -## What is the relationship between *Git for Windows* and *msysGit*? - -*Git for Windows* used to be developed using the development environment called "msysGit", but roughly coinciding with Git 2.1, msysGit was superseded by a new development environment: the [Git for Windows SDK](https://github.com/git-for-windows/build-extra/releases). See [here](https://github.com/git-for-windows/git/wiki/Updating-your-SDK) to get a copy. - -## Some native console programs don't work when run from Git Bash. How to fix it? - -*Git for Windows* defaults to using [mintty](http://mintty.github.io/) terminal. Compared to default Windows console host, it provides normal multi-line cut&paste, working resizing, defaults to unicode font and avoids some bugs in the default console host. However it does not present itself as console to native applications (those *not* built with MSys or Cygwin), so in these applications: - - * Non-ASCII output may be corrupted due to mismatch in character sets (MSYS2 and Cygwin use UTF-8 while Windows will fall back to the legacy DOS codepages in this case). - * Interactive and full-screen applications won't work at all. - -There are several methods for working around these problems: - - * Run programs that have problems using the [`winpty`](https://github.com/rprichard/winpty) utility. This allows you to keep using the nicer mintty terminal, but can become unwieldy if you need the workaround for many programs. - * Modify the shortcut for Git Bash to run `bash` directly without `mintty` so it uses the default console host and configure it for "Quick Edit", reasonable size and scroll-back and suitable unicode font. You'll still have to live with the other quirks of console host. - * Install and use [ConEmu](https://conemu.github.io/). - -## I get errors trying to check out files with long path names. -Windows file paths are by default limited to 260 characters. Some repositories may have committed files which contain paths longer than the limit. By default, *Git for Windows* does not support long paths, and will print errors when trying to perform any operation on a long file name. Set the configuration property `core.longpaths` to true to allow certain Git operations to properly handle these files. See [this wiki page](https://github.com/git-for-windows/git/wiki/Git-cannot-create-a-file-or-directory-with-a-long-path) for more information. - -## The installed files are duplicated and look massive - Why? -All the apparent copies are simply hard links - see Issue 1997 [Use symbolic links for libexec](https://github.com/git-for-windows/git/issues/1997) for more details. - -## Excel file modifications not always noticed. -Excel (and some other apps) do not update the *modified time* of its files which is used by Git to quickly detect changes. Rather Excel used the *change time* field. Git will notice the modifications if a `git status` is performed. See [issue 1000](https://github.com/git-for-windows/git/issues/1000#issuecomment-301611003) if you need more background. - -## How do I access a repository hosted on a Microsoft Team Foundation Server inside a Windows domain? - -The Microsoft Team Foundation Server is capable of hosting git repositories. If the server is a member of a windows domain, and your user account is in that domain, you can use domain authentication to identify yourself to the server, and can thus access git repositories without having to enter any credentials. For this to work, the server has to be configured to use domain authentication, _not_ NTLM authentication. The repository URL can be obtained from the TFS web interface, it may look like http://server.example.com:8080/tfs/TWA/TeamDev/_git/reponame. - -In order to instruct git to use domain authentication, prefix the server name with `:@`, like so: `http://:@server.example.com:8080/tfs/TWA/TeamDev/_git/reponame`. This is a special case of the usual `username:password@server` syntax, where both the `username` and `password` fields are empty. This causes git to look up and use your domain credentials. - -See also: [Clone an existing Git repo - Azure Repos](https://docs.microsoft.com/en-us/azure/devops/repos/git/clone) - -## I get "Permission denied (publickey)." when using git pull or git clone - -### DSA keys -Some DSA keys are not considered secure anymore by OpenSSH 7. Adding "PubkeyAcceptedKeyTypes ssh-dss" to ~/.ssh/config helps. - -### Running without Git Bash -If you choose to use OpenSSH that comes with git during installation (default option) and wish to work from Windows' Command Prompt (cmd) or PowerShell instead of Git Bash you should make sure: - -1. You're calling the correct executables. -Windows comes with a different OpenSSH distribution and by default you might be calling it while git commands use its own. -Set the environment PATH to use the git installation ssh commands first, those are usually at `C:\Program Files\Git\usr\bin`. -In CMD: `set PATH=C:\Program Files\Git\usr\bin;%PATH%` -In PowerShell: `$Env:PATH = "C:\Program Files\Git\usr\bin;$Env:PATH"` -This will make sure, for example, that you add the private keys to the correct _ssh-agent service_ when calling `ssh-add`. -Otherwise you might be asked to introduce the passphrase on each git command call that connects to a remote repository. - -2. Git's ssh is able to connect to the ssh-agent. -In order to connect to the _ssh-agent service_, git's ssh needs to know _how_. This is accomplished by two environment variables called `SSH_AGENT_PID` and `SSH_AUTH_SOCK`. -Luckily, there is a convenient script `start-ssh-agent.cmd` included with the git installation you can call to set this up. The values are dynamic and only valid after calling the script. Forgetting to set them will fail silently, so be sure to call the script each time you open a new command prompt. - -## Switch locale for git-bash launcher (of Git for Windows SDK) - -Some developers want to start git-bash (of Git for Windows SDK) with a different language. -To achieve this in windows following command could be placed inside the launcher: -`C:\Windows\System32\cmd.exe /c "set LANG=en_GB && start C:\git-sdk-64\git-bash.exe && exit"` -replace `en_GB` with your preferred locale. - -## I have errors while building the solution in Visual studio -(i.e. `fatal error C1083: Cannot open include file: 'openssl/ssl.h': No such file or directory`) - -Try to open the console and invoke `git\compat\vcbuild\vcpkg_install.bat`. Make sure that it has completed successfully, then clean and rebuild the solution. - -Ensure also that you are using proper Build Tools (v140). It's going by default in VS 2015. If you are using VS 2017, you need to install them manually. Do not upgrade the project to v141 - it can't be done automatically. - -## Licenses - -Reproduced from [Git for Windows' release notes](https://github.com/git-for-windows/build-extra/blob/HEAD/ReleaseNotes.md#licenses): - -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. - -Git for Windows also contains Embedded CAcert Root Certificates. For more information please go to https://www.cacert.org/policy/RootDistributionLicense.php. - -This package contains software from a number of other projects including Bash, zlib, curl, tcl/tk, perl, MSYS2 and a number of libraries and utilities from the GNU project, licensed under the GNU General Public License. Likewise, it contains Perl which is dual licensed under the GNU General Public License and the Artistic License. From 38518abb56fd08be439dea90f3c3706786076bab Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Matthias=20A=C3=9Fhauer?= Date: Sun, 12 May 2024 09:32:25 +0200 Subject: [PATCH 587/591] Revert 6ffc9b132e445d74bfeb9c286eacb2db1d94e81c...325fc9b01f16aac3fd32257f72be8bbc7c222723 --- FAQ.md | 145 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 145 insertions(+) create mode 100644 FAQ.md diff --git a/FAQ.md b/FAQ.md new file mode 100644 index 00000000000000..6097d3f0d6e7de --- /dev/null +++ b/FAQ.md @@ -0,0 +1,145 @@ +## Which versions of Windows are supported? + +Git for Windows currently works with all recent, commercially released x86 32 bit and 64 bit versions of Windows, starting with Windows 7 SP1. + +*** +NOTE: Git for Windows version [2.37.1](https://github.com/git-for-windows/git/releases/tag/v2.37.1.windows.1) was the last version supporting Windows Vista and Server 2008. +*** + +*** +NOTE: Git for Windows version [2.10.0](https://github.com/git-for-windows/git/releases/tag/v2.10.0.windows.1) was the last version supporting Windows XP and Server 2003. +*** + +Windows XP and Windows Server 2003 are long past their end of life, hence support for these versions was dropped from Git for Windows 2.10.1 and later. This limitation is inherited by Git's use of MSYS2, which in turn inherited it from [Cygwin](https://cygwin.com/ml/cygwin/2015-08/msg00446.html). + +More information here: [Git for Windows' prerequisites](https://gitforwindows.org/requirements.html). + +## Is there an MSI for installation via Group Policy? + +There is currently no MSI package; there is an exe installer and a portable package. You are welcome to contribute a Pull Request that packages a new installer. + +~There is an existing Pull Request in development and looking for testers, please try out https://github.com/robmen/gitsetup/issues/1 and give feedback.~ It's closed by now. Future development is happening [here](https://github.com/git-for-windows/build-extra/tree/HEAD/msi/). + +In the meantime you could try: + + * using the portable package + * deploying the exe installer with System Center Configuration Manager + * deploying the portable package via a script + * deploying the Chocolatey package via Puppet (or something similar) + +## Should I upgrade to a newer Git for Windows version? + +In general, yes: it is a good idea to stay up-to-date. + +If you have a version older than 2.40.1, it is *highly* advisable to upgrade. A couple of Git versions came with important fixes to security-relevant vulnerabilities: 2.40.1, 2.39.2, 2.39.1, 2.38.1, 2.37.1, 2.36.0, 2.35.3, 2.35.3, 2.30.2, 2.30.0(2), 2.29.2(3), 2.29.2(2), 2.26.1, 2.24.1(2), 2.17.1(2), 2.14.1, 2.7.4, 2.7.0, 2.6.1, 2.5.2, 1.9.5-preview20150319, and 1.9.5-preview20141217. + +## How do I update *Git for Windows* upon new releases? + +This depends on how you installed *Git for Windows*. The bundle installation requires you to download and install the new version. Any customizations you made will be kept as long as you did so in the appropriate configuration folders. + +*Git for Windows* comes with a tool to check for updates and offer to install them. Whether or not you enabled auto-updates during installation, you can manually run `git update-git-for-windows`. (For help, run `git update-git-for-windows -h`.) + +For advanced users working with the *Git for Windows* SDK `pacman` is available as a package manager. See [Package management](Package-management) + +## How do I check the release hash and release notes + +For hashes see https://github.com/git-for-windows/git/releases + +For (G4W) release notes see the [build-extra repo](https://github.com/git-for-windows/build-extra/blob/HEAD/ReleaseNotes.md), or the top level of your installation (e.g. [C:\Program Files\Git\ReleaseNotes.html](https://www.example.com/Program%20Files/Git/ReleaseNotes.html) - via manual browsing). + +For extracting 7z/zip archives see [page](https://github.com/git-for-windows/git/wiki/Zip-Archives---extracting-the-released-archives). + +## Are there 'Nightly' builds of the latest and greatest + +The Git for Windows builds are not quite that frequent, but there are Snapshot builds listed at https://wingit.blob.core.windows.net/files/index.html + +These often 'fix' (or attempt fixes) recent issues before a new formal release. Check their commit notes and links to issues to see if your problem is included. + +## What is the release cadence of Git for Windows? + +Official Git for Windows versions mainly follow Git's release cycle: every 12 weeks or so, a new major Git version is released (see details here: https://tinyurl.com/gitCal). Typically, Git for Windows will follow suit within a day. + +Other than that, Git for Windows follows the *newest* Git version's maintenance releases (read: after Git for Windows v2.15.0 was released, no new Git for Windows v2.14.x version would be released). Indicators for imminent maintenance releases of Git are: + +- The Git maintainer sometimes talks about this in the preamble of the ["What's cooking in git.git" mails](https://public-inbox.org/git/?q=s%3A%22what%27s+cooking%22+AND+f%3Agitster%40pobox.com). +- The [`maint` in git.git](https://github.com/git/git/commits/maint) accumulates critical patches. + +Finally, Git for Windows is sometimes released in "out-of-band" versions, when critical fixes specific to Git for Windows necessitate it. These out-of-band versions are indicated by appending a `(2)` to the latest release (or `(3)`, `(4)`, etc). Examples for such out-of-band versions include: [Git for Windows v2.15.1(2)](https://github.com/git-for-windows/git/releases/tag/v2.15.1.windows.2) and [Git for Windows v2.16.1(4)](https://github.com/git-for-windows/git/releases/tag/v2.16.1.windows.4). + +## What is the relationship between *Git for Windows* and *msysGit*? + +*Git for Windows* used to be developed using the development environment called "msysGit", but roughly coinciding with Git 2.1, msysGit was superseded by a new development environment: the [Git for Windows SDK](https://github.com/git-for-windows/build-extra/releases). See [here](https://github.com/git-for-windows/git/wiki/Updating-your-SDK) to get a copy. + +## Some native console programs don't work when run from Git Bash. How to fix it? + +*Git for Windows* defaults to using [mintty](http://mintty.github.io/) terminal. Compared to default Windows console host, it provides normal multi-line cut&paste, working resizing, defaults to unicode font and avoids some bugs in the default console host. However it does not present itself as console to native applications (those *not* built with MSys or Cygwin), so in these applications: + + * Non-ASCII output may be corrupted due to mismatch in character sets (MSYS2 and Cygwin use UTF-8 while Windows will fall back to the legacy DOS codepages in this case). + * Interactive and full-screen applications won't work at all. + +There are several methods for working around these problems: + + * Run programs that have problems using the [`winpty`](https://github.com/rprichard/winpty) utility. This allows you to keep using the nicer mintty terminal, but can become unwieldy if you need the workaround for many programs. + * Modify the shortcut for Git Bash to run `bash` directly without `mintty` so it uses the default console host and configure it for "Quick Edit", reasonable size and scroll-back and suitable unicode font. You'll still have to live with the other quirks of console host. + * Install and use [ConEmu](https://conemu.github.io/). + +## I get errors trying to check out files with long path names. +Windows file paths are by default limited to 260 characters. Some repositories may have committed files which contain paths longer than the limit. By default, *Git for Windows* does not support long paths, and will print errors when trying to perform any operation on a long file name. Set the configuration property `core.longpaths` to true to allow certain Git operations to properly handle these files. See [this wiki page](https://github.com/git-for-windows/git/wiki/Git-cannot-create-a-file-or-directory-with-a-long-path) for more information. + +## The installed files are duplicated and look massive - Why? +All the apparent copies are simply hard links - see Issue 1997 [Use symbolic links for libexec](https://github.com/git-for-windows/git/issues/1997) for more details. + +## Excel file modifications not always noticed. +Excel (and some other apps) do not update the *modified time* of its files which is used by Git to quickly detect changes. Rather Excel used the *change time* field. Git will notice the modifications if a `git status` is performed. See [issue 1000](https://github.com/git-for-windows/git/issues/1000#issuecomment-301611003) if you need more background. + +## How do I access a repository hosted on a Microsoft Team Foundation Server inside a Windows domain? + +The Microsoft Team Foundation Server is capable of hosting git repositories. If the server is a member of a windows domain, and your user account is in that domain, you can use domain authentication to identify yourself to the server, and can thus access git repositories without having to enter any credentials. For this to work, the server has to be configured to use domain authentication, _not_ NTLM authentication. The repository URL can be obtained from the TFS web interface, it may look like http://server.example.com:8080/tfs/TWA/TeamDev/_git/reponame. + +In order to instruct git to use domain authentication, prefix the server name with `:@`, like so: `http://:@server.example.com:8080/tfs/TWA/TeamDev/_git/reponame`. This is a special case of the usual `username:password@server` syntax, where both the `username` and `password` fields are empty. This causes git to look up and use your domain credentials. + +See also: [Clone an existing Git repo - Azure Repos](https://docs.microsoft.com/en-us/azure/devops/repos/git/clone) + +## I get "Permission denied (publickey)." when using git pull or git clone + +### DSA keys +Some DSA keys are not considered secure anymore by OpenSSH 7. Adding "PubkeyAcceptedKeyTypes ssh-dss" to ~/.ssh/config helps. + +### Running without Git Bash +If you choose to use OpenSSH that comes with git during installation (default option) and wish to work from Windows' Command Prompt (cmd) or PowerShell instead of Git Bash you should make sure: + +1. You're calling the correct executables. +Windows comes with a different OpenSSH distribution and by default you might be calling it while git commands use its own. +Set the environment PATH to use the git installation ssh commands first, those are usually at `C:\Program Files\Git\usr\bin`. +In CMD: `set PATH=C:\Program Files\Git\usr\bin;%PATH%` +In PowerShell: `$Env:PATH = "C:\Program Files\Git\usr\bin;$Env:PATH"` +This will make sure, for example, that you add the private keys to the correct _ssh-agent service_ when calling `ssh-add`. +Otherwise you might be asked to introduce the passphrase on each git command call that connects to a remote repository. + +2. Git's ssh is able to connect to the ssh-agent. +In order to connect to the _ssh-agent service_, git's ssh needs to know _how_. This is accomplished by two environment variables called `SSH_AGENT_PID` and `SSH_AUTH_SOCK`. +Luckily, there is a convenient script `start-ssh-agent.cmd` included with the git installation you can call to set this up. The values are dynamic and only valid after calling the script. Forgetting to set them will fail silently, so be sure to call the script each time you open a new command prompt. + +## Switch locale for git-bash launcher (of Git for Windows SDK) + +Some developers want to start git-bash (of Git for Windows SDK) with a different language. +To achieve this in windows following command could be placed inside the launcher: +`C:\Windows\System32\cmd.exe /c "set LANG=en_GB && start C:\git-sdk-64\git-bash.exe && exit"` +replace `en_GB` with your preferred locale. + +## I have errors while building the solution in Visual studio +(i.e. `fatal error C1083: Cannot open include file: 'openssl/ssl.h': No such file or directory`) + +Try to open the console and invoke `git\compat\vcbuild\vcpkg_install.bat`. Make sure that it has completed successfully, then clean and rebuild the solution. + +Ensure also that you are using proper Build Tools (v140). It's going by default in VS 2015. If you are using VS 2017, you need to install them manually. Do not upgrade the project to v141 - it can't be done automatically. + +## Licenses + +Reproduced from [Git for Windows' release notes](https://github.com/git-for-windows/build-extra/blob/HEAD/ReleaseNotes.md#licenses): + +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. + +Git for Windows also contains Embedded CAcert Root Certificates. For more information please go to https://www.cacert.org/policy/RootDistributionLicense.php. + +This package contains software from a number of other projects including Bash, zlib, curl, tcl/tk, perl, MSYS2 and a number of libraries and utilities from the GNU project, licensed under the GNU General Public License. Likewise, it contains Perl which is dual licensed under the GNU General Public License and the Artistic License. From b78c1dc4bfcaa96313a5a20937334094e429f0fd Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Sun, 12 May 2024 21:04:27 +0200 Subject: [PATCH 588/591] Remove the wiki footer This file is no longer used after the merge into the main repository. Signed-off-by: Johannes Schindelin --- Documentation/git-for-windows/_Footer.md | 1 - 1 file changed, 1 deletion(-) delete mode 100644 Documentation/git-for-windows/_Footer.md diff --git a/Documentation/git-for-windows/_Footer.md b/Documentation/git-for-windows/_Footer.md deleted file mode 100644 index 472997268e045b..00000000000000 --- a/Documentation/git-for-windows/_Footer.md +++ /dev/null @@ -1 +0,0 @@ -This is the _Git for Windows_ wiki. See [how-to-participate](https://gitforwindows.org/governance-model.html). From 3303759ef97c879baa27c17506d9e002726dc880 Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Sun, 12 May 2024 21:48:24 +0200 Subject: [PATCH 589/591] Fix two incorrect links in the imported wiki These were stale for a while, it would appear. Signed-off-by: Johannes Schindelin --- Documentation/git-for-windows/0.-Index.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/Documentation/git-for-windows/0.-Index.md b/Documentation/git-for-windows/0.-Index.md index 498ba6aa5f2d8b..412bf9d4087f98 100644 --- a/Documentation/git-for-windows/0.-Index.md +++ b/Documentation/git-for-windows/0.-Index.md @@ -12,7 +12,7 @@ This is for the poor souls in corporate IE environments who can't expand the pag * [Continuous Integration (CI)](https://github.com/git-for-windows/git/wiki/Continuous-Integration-(CI)) * [Debugging Git](https://github.com/git-for-windows/git/wiki/Debugging-Git) * [Diagnosing performance issues](https://github.com/git-for-windows/git/wiki/Diagnosing-performance-issues) -* [exec() semantics](https://github.com/git-for-windows/git/wiki/exec()-semantics) +* [exec() semantics](https://github.com/git-for-windows/git/wiki/Windows-vs-Linux-fork()/exec()-semantics) * [FAQ](https://github.com/git-for-windows/git/wiki/FAQ) * [File names, Branch names, Path quotation, Executable bit and file modes, core.FileMode](https://github.com/git-for-windows/git/wiki/File-names,-Branch-names,-Path-quotation,-Executable-bit-and-file-modes,-core.FileMode) * [Git cannot create a file or directory with a long path](https://github.com/git-for-windows/git/wiki/Git-cannot-create-a-file-or-directory-with-a-long-path) @@ -34,7 +34,7 @@ This is for the poor souls in corporate IE environments who can't expand the pag * [Rebasing Git for Windows](https://github.com/git-for-windows/git/wiki/Rebasing-Git-for-Windows) * [Release Hashes](https://github.com/git-for-windows/git/wiki/Release-Hashes) * [Running Git's regression tests](https://github.com/git-for-windows/git/wiki/Running-Git's-regression-tests) -* [Setting your Core.Editor ( e.g. Notepad )](https://github.com/git-for-windows/git/wiki/Setting-your-Core.Editor-(-e.g.-Notepad-)) +* [Setting your Core.Editor (e.g. Notepad++)](https://github.com/git-for-windows/git/wiki/Setting-your-Core.Editor-(e.g.-Notepad-Plus-Plus)) * [Silent or Unattended Installation](https://github.com/git-for-windows/git/wiki/Silent-or-Unattended-Installation) * [Sourcetrail code viewer and linkage to Visual Studio, for Git](https://github.com/git-for-windows/git/wiki/Sourcetrail-code-viewer-and-linkage-to-Visual-Studio,-for-Git) * [Symbolic Links](https://github.com/git-for-windows/git/wiki/Symbolic-Links) From 4dff2ecd74f783d12d592c7238c359bfcce0f76c Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Sun, 12 May 2024 20:33:02 +0200 Subject: [PATCH 590/591] Change all links to the wiki Since we just merged the wiki into the main repository (to stave off future vandalism), let's change the links in this here repository so they point at the new location. This trick was performed by: # Construct `sed` instructions for replacing the basenames of the wiki # links with URL-encoded versions that also add the Markdown file # extension `.md`, being careful only to replace the actual Markdown # _links_ (i.e. the basename must be preceded either by a slash or by # an opening parenthesis, and followed by a closing parenthesis or # a hash character indicating an anchor). extra="$(git -C Documentation/git-for-windows/ ls-files | sed -n '/\.md$/{ s|`|%60|g h s|'\''|%27|g s|(|%28|g s|)|%29|g x s|\.md$|| s|'\''|&\\&&|g s|\.|\\&|g G s|^|-e '\''s@\\([/(]\\)| s|\n|\\([#)]\\)@\\1| s|$|\\2@g'\''| p }' | tr '\n' ' ' )" # Edit all files containing links to the Git for Windows wiki for f in $(git grep -l git-for-windows/git/wiki) do eval sed -i "$extra" \ -e \''s|\(git-for-windows/git/\)wiki/|\1blob/HEAD/Documentation/git-for-windows/|g'\' \ -e \''s|\(git-for-windows/git/\)wiki|\1blob/HEAD/Documentation/git-for-windows/Home.md|g'\' \ \'"$f"\' done It will need to be repeated in the `build-extra` and `git-for-windows.github.io` repositories. Signed-off-by: Johannes Schindelin --- CONTRIBUTING.md | 6 +- Documentation/git-for-windows/0.-Index.md | 94 +++++++++---------- Documentation/git-for-windows/Building-Git.md | 4 +- .../Building-new-package-versions.md | 4 +- .../Compiling-Git-with-Visual-Studio.md | 4 +- Documentation/git-for-windows/Contact.md | 2 +- .../Diagnosing-performance-issues.md | 2 +- Documentation/git-for-windows/FAQ.md | 8 +- Documentation/git-for-windows/Git-wrapper.md | 2 +- Documentation/git-for-windows/Home.md | 4 +- .../git-for-windows/How-to-participate.md | 4 +- ...MSYS2,-Cygwin-or-Git-for-windows-itself.md | 2 +- .../git-for-windows/Making-a-portable-Git.md | 2 +- .../git-for-windows/Making-an-installer.md | 2 +- ...GUI-Settings-And-Command-Line-Arguments.md | 2 +- ...flicts---Resolving-and-Remembering-them.md | 2 +- .../Rebasing-Git-for-Windows.md | 2 +- .../git-for-windows/Technical-overview.md | 16 ++-- .../The-difference-between-MINGW-and-MSYS2.md | 2 +- .../git-for-windows/Updating-your-SDK.md | 2 +- ...g-the-`perl`-component-to-a-new-version.md | 4 +- .../Visual-Studio-and-MSVC-compilation.md | 4 +- .../exec()-semantics.md | 4 +- README.md | 2 +- SECURITY.md | 2 +- 25 files changed, 91 insertions(+), 91 deletions(-) diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index ca9770df8c4808..6a2d970934741b 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -39,8 +39,8 @@ When running `make`, you can use `-j$(nproc)` to automatically use the number of on your machine as the number of concurrent build processes. You can go deeper on the Windows-specific build process by reading the -[technical overview](https://github.com/git-for-windows/git/wiki/Technical-overview) or the -[guide to compiling Git with Visual Studio](https://github.com/git-for-windows/git/wiki/Compiling-Git-with-Visual-Studio). +[technical overview](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Technical-overview.md) or the +[guide to compiling Git with Visual Studio](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Compiling-Git-with-Visual-Studio.md). ## Building `git` on Windows with Visual Studio @@ -120,7 +120,7 @@ you want to extend the functional tests to be sure no one breaks your feature in ### Functional Tests Navigate to the `t/` directory and type `make` to run all tests or use `prove` as -[described in the Git for Windows wiki](https://github.com/git-for-windows/git/wiki/Building-Git): +[described in the Git for Windows wiki](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Building-Git.md): ``` prove -j12 --state=failed,save ./t[0-9]*.sh diff --git a/Documentation/git-for-windows/0.-Index.md b/Documentation/git-for-windows/0.-Index.md index 412bf9d4087f98..91f7c83ff11e00 100644 --- a/Documentation/git-for-windows/0.-Index.md +++ b/Documentation/git-for-windows/0.-Index.md @@ -1,51 +1,51 @@ This is for the poor souls in corporate IE environments who can't expand the page list. -* [Home](https://github.com/git-for-windows/git/wiki) -* [32 bit issues](https://github.com/git-for-windows/git/wiki/32-bit-issues) -* [Adding regression tests](https://github.com/git-for-windows/git/wiki/Adding-regression-tests) -* [Auto launching ssh agent when git starts](https://github.com/git-for-windows/git/wiki/Auto-launching-ssh-agent-when-git-starts) -* [Building Git](https://github.com/git-for-windows/git/wiki/Building-Git) -* [Building msys2 runtime](https://github.com/git-for-windows/git/wiki/Building-msys2-runtime) -* [Building new package versions](https://github.com/git-for-windows/git/wiki/Building-new-package-versions) -* [Compiling Git with Visual Studio](https://github.com/git-for-windows/git/wiki/Compiling-Git-with-Visual-Studio) -* [Contact](https://github.com/git-for-windows/git/wiki/Contact) -* [Continuous Integration (CI)](https://github.com/git-for-windows/git/wiki/Continuous-Integration-(CI)) -* [Debugging Git](https://github.com/git-for-windows/git/wiki/Debugging-Git) -* [Diagnosing performance issues](https://github.com/git-for-windows/git/wiki/Diagnosing-performance-issues) -* [exec() semantics](https://github.com/git-for-windows/git/wiki/Windows-vs-Linux-fork()/exec()-semantics) -* [FAQ](https://github.com/git-for-windows/git/wiki/FAQ) -* [File names, Branch names, Path quotation, Executable bit and file modes, core.FileMode](https://github.com/git-for-windows/git/wiki/File-names,-Branch-names,-Path-quotation,-Executable-bit-and-file-modes,-core.FileMode) -* [Git cannot create a file or directory with a long path](https://github.com/git-for-windows/git/wiki/Git-cannot-create-a-file-or-directory-with-a-long-path) -* [Git-for-Windows' "snapshots"](https://github.com/git-for-windows/git/wiki/Snapshot-builds) -* [Good commits](https://github.com/git-for-windows/git/wiki/Good-commits) -* [How to participate](https://github.com/git-for-windows/git/wiki/How-to-participate) -* [Install inside MSYS2 proper](https://github.com/git-for-windows/git/wiki/Install-inside-MSYS2-proper) -* [Install or update inside MSYS2, Cygwin or Git-for-windows itself](https://github.com/git-for-windows/git/wiki/Install-or-update-inside-MSYS2,-Cygwin-or-Git-for-windows-itself) -* [Issue reporting guidelines](https://github.com/git-for-windows/git/wiki/Issue-reporting-guidelines) -* [Making a portable Git](https://github.com/git-for-windows/git/wiki/Making-a-portable-Git) -* [Making an installer](https://github.com/git-for-windows/git/wiki/Making-an-installer) -* [Mapping between Git Installer GUI Settings And Command Line Arguments](https://github.com/git-for-windows/git/wiki/Mapping-between-Git-Installer-GUI-Settings-And-Command-Line-Arguments) -* [Merge Conflicts Resolving and Remembering them](https://github.com/git-for-windows/git/wiki/Merge-Conflicts---Resolving-and-Remembering-them) -* [MinGit is Git for Windows Applications](https://github.com/git-for-windows/git/wiki/MinGit) -* [MSYS2 Notes](https://github.com/git-for-windows/git/wiki/MSYS2-Notes) -* [OpenSSH Integration with Pageant](https://github.com/git-for-windows/git/wiki/OpenSSH-Integration-with-Pageant) -* [Package management](https://github.com/git-for-windows/git/wiki/Package-management) -* [Performance profiling with Visual Studio](https://github.com/git-for-windows/git/wiki/Performance-profiling-with-Visual-Studio) -* [Rebasing Git for Windows](https://github.com/git-for-windows/git/wiki/Rebasing-Git-for-Windows) -* [Release Hashes](https://github.com/git-for-windows/git/wiki/Release-Hashes) -* [Running Git's regression tests](https://github.com/git-for-windows/git/wiki/Running-Git's-regression-tests) -* [Setting your Core.Editor (e.g. Notepad++)](https://github.com/git-for-windows/git/wiki/Setting-your-Core.Editor-(e.g.-Notepad-Plus-Plus)) -* [Silent or Unattended Installation](https://github.com/git-for-windows/git/wiki/Silent-or-Unattended-Installation) -* [Sourcetrail code viewer and linkage to Visual Studio, for Git](https://github.com/git-for-windows/git/wiki/Sourcetrail-code-viewer-and-linkage-to-Visual-Studio,-for-Git) -* [Symbolic Links](https://github.com/git-for-windows/git/wiki/Symbolic-Links) -* [Technical overview](https://github.com/git-for-windows/git/wiki/Technical-overview) -* [The "Git-wrapper"](https://github.com/git-for-windows/git/wiki/Git-wrapper) -* [The difference between MINGW and MSYS2](https://github.com/git-for-windows/git/wiki/The-difference-between-MINGW-and-MSYS2) -* [Updating your SDK](https://github.com/git-for-windows/git/wiki/Updating-your-SDK) -* [Upgrading the 'perl' component to a new version](https://github.com/git-for-windows/git/wiki/Upgrading-the-%60perl%60-component-to-a-new-version) -* [Using sshd to host a git server](https://github.com/git-for-windows/git/wiki/Using-sshd-to-host-a-git-server) -* [Vagrant](https://github.com/git-for-windows/git/wiki/Vagrant) -* [Visual Studio and MSVC compilation](https://github.com/git-for-windows/git/wiki/Visual-Studio-and-MSVC-compilation) -* [Zip Archives extracting the released archives](https://github.com/git-for-windows/git/wiki/Zip-Archives---extracting-the-released-archives) +* [Home](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Home.md) +* [32 bit issues](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/32-bit-issues.md) +* [Adding regression tests](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Adding-regression-tests.md) +* [Auto launching ssh agent when git starts](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Auto-launching-ssh-agent-when-git-starts.md) +* [Building Git](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Building-Git.md) +* [Building msys2 runtime](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Building-msys2-runtime.md) +* [Building new package versions](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Building-new-package-versions.md) +* [Compiling Git with Visual Studio](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Compiling-Git-with-Visual-Studio.md) +* [Contact](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Contact.md) +* [Continuous Integration (CI)](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Continuous-Integration-%28CI%29.md) +* [Debugging Git](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Debugging-Git.md) +* [Diagnosing performance issues](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Diagnosing-performance-issues.md) +* [exec() semantics](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Windows-vs-Linux-fork%28%29/exec%28%29-semantics.md) +* [FAQ](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/FAQ.md) +* [File names, Branch names, Path quotation, Executable bit and file modes, core.FileMode](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/File-names,-Branch-names,-Path-quotation,-Executable-bit-and-file-modes,-core.FileMode.md) +* [Git cannot create a file or directory with a long path](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Git-cannot-create-a-file-or-directory-with-a-long-path.md) +* [Git-for-Windows' "snapshots"](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Snapshot-builds.md) +* [Good commits](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Good-commits.md) +* [How to participate](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/How-to-participate.md) +* [Install inside MSYS2 proper](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Install-inside-MSYS2-proper.md) +* [Install or update inside MSYS2, Cygwin or Git-for-windows itself](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Install-or-update-inside-MSYS2,-Cygwin-or-Git-for-windows-itself.md) +* [Issue reporting guidelines](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Issue-reporting-guidelines.md) +* [Making a portable Git](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Making-a-portable-Git.md) +* [Making an installer](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Making-an-installer.md) +* [Mapping between Git Installer GUI Settings And Command Line Arguments](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Mapping-between-Git-Installer-GUI-Settings-And-Command-Line-Arguments.md) +* [Merge Conflicts Resolving and Remembering them](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Merge-Conflicts---Resolving-and-Remembering-them.md) +* [MinGit is Git for Windows Applications](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/MinGit.md) +* [MSYS2 Notes](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/MSYS2-Notes.md) +* [OpenSSH Integration with Pageant](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/OpenSSH-Integration-with-Pageant.md) +* [Package management](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Package-management.md) +* [Performance profiling with Visual Studio](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Performance-profiling-with-Visual-Studio.md) +* [Rebasing Git for Windows](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Rebasing-Git-for-Windows.md) +* [Release Hashes](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Release-Hashes.md) +* [Running Git's regression tests](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Running-Git%27s-regression-tests.md) +* [Setting your Core.Editor (e.g. Notepad++)](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Setting-your-Core.Editor-%28e.g.-Notepad-Plus-Plus%29.md) +* [Silent or Unattended Installation](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Silent-or-Unattended-Installation.md) +* [Sourcetrail code viewer and linkage to Visual Studio, for Git](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Sourcetrail-code-viewer-and-linkage-to-Visual-Studio,-for-Git.md) +* [Symbolic Links](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Symbolic-Links.md) +* [Technical overview](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Technical-overview.md) +* [The "Git-wrapper"](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Git-wrapper.md) +* [The difference between MINGW and MSYS2](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/The-difference-between-MINGW-and-MSYS2.md) +* [Updating your SDK](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Updating-your-SDK.md) +* [Upgrading the 'perl' component to a new version](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Upgrading-the-%60perl%60-component-to-a-new-version.md) +* [Using sshd to host a git server](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Using-sshd-to-host-a-git-server.md) +* [Vagrant](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Vagrant.md) +* [Visual Studio and MSVC compilation](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Visual-Studio-and-MSVC-compilation.md) +* [Zip Archives extracting the released archives](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Zip-Archives---extracting-the-released-archives.md) -Fin- diff --git a/Documentation/git-for-windows/Building-Git.md b/Documentation/git-for-windows/Building-Git.md index 44c7874a742657..b93f8997229c50 100644 --- a/Documentation/git-for-windows/Building-Git.md +++ b/Documentation/git-for-windows/Building-Git.md @@ -26,7 +26,7 @@ Once the SDK built Git, it is *very* easy to build another revision of Git, such 1. if you want to test a Pull Request, call `git fetch origin refs/pull//head`, where `` is the number of the Pull Request (e.g. if you want to test Pull Request #606, you would call `git fetch origin refs/pull/606/head`), 2. if you want to test a custom branch, call `git fetch ` instead, where `` is the URL of the repository and `` is the name of the branch to test (e.g. if you wanted to test @dscho's `cool-new-feature` branch, you would call `git fetch https://github.com/dscho/git cool-new-feature`), 4. check out the revision that was just fetched: `git checkout FETCH_HEAD`, -5. continue as [above](https://github.com/git-for-windows/git/wiki/Building-Git#build-git) either by `make install` or `make test`. +5. continue as [above](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Building-Git.md#build-git) either by `make install` or `make test`. # Updating to the newest Git for Windows version @@ -48,7 +48,7 @@ cd /usr/src/git/t ## See also Regression Testing Single tests, block of tests, or the whole test suite can be run, as detailed in -[Running Git's regression-tests](https://github.com/git-for-windows/git/wiki/Running-Git's-regression-tests) +[Running Git's regression-tests](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Running-Git%27s-regression-tests.md) --- diff --git a/Documentation/git-for-windows/Building-new-package-versions.md b/Documentation/git-for-windows/Building-new-package-versions.md index 83641c6d36762b..8a27c8ff05ea85 100644 --- a/Documentation/git-for-windows/Building-new-package-versions.md +++ b/Documentation/git-for-windows/Building-new-package-versions.md @@ -1,4 +1,4 @@ -As described in [Package management](Package-management), Git for Windows' SDK is a close derivative of the [MSYS2](https://msys2.github.io/) system, and as such, its components are built using `makepkg` and `makepkg-mingw` (borrowed from Arch Linux' [`pacman`](https://wiki.archlinux.org/index.php/Pacman)). +As described in [Package management](Package-management.md), Git for Windows' SDK is a close derivative of the [MSYS2](https://msys2.github.io/) system, and as such, its components are built using `makepkg` and `makepkg-mingw` (borrowed from Arch Linux' [`pacman`](https://wiki.archlinux.org/index.php/Pacman)). Most of those packages are actually built by the MSYS2 project and consumed by Git for Windows. However, a couple of components (including cURL and OpenSSH) _are_ built by Git for Windows, e.g. to be able to react faster to newly-available versions, or to allow for modifications specific to Git for Windows. @@ -37,4 +37,4 @@ The strategy that worked best for the Git for Windows maintainer goes like this: 9. test (`cd ../.. && sdk build`) 10. commit, push (and open a PR unless pushing directly to `main`) -Caveat: this strategy needs manual adjustments if the archive in question contains files with DOS line endings (I am looking at you, [Perl](https://github.com/git-for-windows/git/wiki/Upgrading-the-%60perl%60-component-to-a-new-version) _shakes fist_): `import-tars.perl` will happily import those verbatim, but the `bsdtar` used by `makepkg` to unpack the archive will convert them to Unix line endings, and if the patches expect DOS line endings, they won't apply. \ No newline at end of file +Caveat: this strategy needs manual adjustments if the archive in question contains files with DOS line endings (I am looking at you, [Perl](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Upgrading-the-%60perl%60-component-to-a-new-version.md) _shakes fist_): `import-tars.perl` will happily import those verbatim, but the `bsdtar` used by `makepkg` to unpack the archive will convert them to Unix line endings, and if the patches expect DOS line endings, they won't apply. \ No newline at end of file diff --git a/Documentation/git-for-windows/Compiling-Git-with-Visual-Studio.md b/Documentation/git-for-windows/Compiling-Git-with-Visual-Studio.md index 6445f734b8f6d8..e29dc5f31bf923 100644 --- a/Documentation/git-for-windows/Compiling-Git-with-Visual-Studio.md +++ b/Documentation/git-for-windows/Compiling-Git-with-Visual-Studio.md @@ -5,7 +5,7 @@ Please note: this page describes how to compile Git's source code in Visual Stud > [!WARNING] > The `vs/main` branch and `git.sln` is deprecated. The current approach is to open the `git` folder in VS directly, refer to the [README of the `vs/main` branch](https://github.com/git-for-windows/git/tree/vs/main). -Git's source code (and hence also Git for Windows' source code) is [usually built using GNU C and GNU Make in a Git for Windows SDK](https://github.com/git-for-windows/git/wiki/Building-Git). +Git's source code (and hence also Git for Windows' source code) is [usually built using GNU C and GNU Make in a Git for Windows SDK](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Building-Git.md). However, as of Git for Windows v2.11.0, a much more convenient way is available: by cloning https://github.com/git-for-windows/git and checking out the `vs/main` branch, you will automatically have project definitions ready to go with Visual Studio. @@ -40,4 +40,4 @@ prove --timer --jobs 15 ./t[0-9]*.sh # Browsing the code -You can also use the Sourcetrail code browser (now open source) in conjunction with Visual Studio, see [Sourcetrail code viewer](https://github.com/git-for-windows/git/wiki/Sourcetrail-code-viewer-and-linkage-to-Visual-Studio,-for-Git) page. \ No newline at end of file +You can also use the Sourcetrail code browser (now open source) in conjunction with Visual Studio, see [Sourcetrail code viewer](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Sourcetrail-code-viewer-and-linkage-to-Visual-Studio,-for-Git.md) page. \ No newline at end of file diff --git a/Documentation/git-for-windows/Contact.md b/Documentation/git-for-windows/Contact.md index 3c0123b7fe580d..297a26b1abce24 100644 --- a/Documentation/git-for-windows/Contact.md +++ b/Documentation/git-for-windows/Contact.md @@ -2,7 +2,7 @@ Please state the nature of your medical emergency. # I found a bug! -Please follow [our guide lines](https://github.com/git-for-windows/git/wiki/Issue-reporting-guidelines) on reporting bugs. +Please follow [our guide lines](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Issue-reporting-guidelines.md) on reporting bugs. # I have a question! diff --git a/Documentation/git-for-windows/Diagnosing-performance-issues.md b/Documentation/git-for-windows/Diagnosing-performance-issues.md index 3f8681a54f9761..229e944eb84080 100644 --- a/Documentation/git-for-windows/Diagnosing-performance-issues.md +++ b/Documentation/git-for-windows/Diagnosing-performance-issues.md @@ -6,7 +6,7 @@ If the problem lies with a specific Git command, the most straight-forward way t The canonical profiling tool in GCC's tool set is [`gprof`](https://sourceware.org/binutils/docs/gprof/). However, the MINGW version of the GCC tools offered by MSYS2 has been known to produce empty output on occasion. -An more convenient alternative is to use [Visual Studio's Performance Profiler](https://github.com/git-for-windows/git/wiki/Performance-profiling-with-Visual-Studio) (which is available in the free-of-cost Community version) which offers a powerful graphical user interface. +An more convenient alternative is to use [Visual Studio's Performance Profiler](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Performance-profiling-with-Visual-Studio.md) (which is available in the free-of-cost Community version) which offers a powerful graphical user interface. # Trace executions in the Bash startup diff --git a/Documentation/git-for-windows/FAQ.md b/Documentation/git-for-windows/FAQ.md index 6097d3f0d6e7de..aac7fa05193aa1 100644 --- a/Documentation/git-for-windows/FAQ.md +++ b/Documentation/git-for-windows/FAQ.md @@ -39,7 +39,7 @@ This depends on how you installed *Git for Windows*. The bundle installation req *Git for Windows* comes with a tool to check for updates and offer to install them. Whether or not you enabled auto-updates during installation, you can manually run `git update-git-for-windows`. (For help, run `git update-git-for-windows -h`.) -For advanced users working with the *Git for Windows* SDK `pacman` is available as a package manager. See [Package management](Package-management) +For advanced users working with the *Git for Windows* SDK `pacman` is available as a package manager. See [Package management](Package-management.md) ## How do I check the release hash and release notes @@ -47,7 +47,7 @@ For hashes see https://github.com/git-for-windows/git/releases For (G4W) release notes see the [build-extra repo](https://github.com/git-for-windows/build-extra/blob/HEAD/ReleaseNotes.md), or the top level of your installation (e.g. [C:\Program Files\Git\ReleaseNotes.html](https://www.example.com/Program%20Files/Git/ReleaseNotes.html) - via manual browsing). -For extracting 7z/zip archives see [page](https://github.com/git-for-windows/git/wiki/Zip-Archives---extracting-the-released-archives). +For extracting 7z/zip archives see [page](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Zip-Archives---extracting-the-released-archives.md). ## Are there 'Nightly' builds of the latest and greatest @@ -68,7 +68,7 @@ Finally, Git for Windows is sometimes released in "out-of-band" versions, when c ## What is the relationship between *Git for Windows* and *msysGit*? -*Git for Windows* used to be developed using the development environment called "msysGit", but roughly coinciding with Git 2.1, msysGit was superseded by a new development environment: the [Git for Windows SDK](https://github.com/git-for-windows/build-extra/releases). See [here](https://github.com/git-for-windows/git/wiki/Updating-your-SDK) to get a copy. +*Git for Windows* used to be developed using the development environment called "msysGit", but roughly coinciding with Git 2.1, msysGit was superseded by a new development environment: the [Git for Windows SDK](https://github.com/git-for-windows/build-extra/releases). See [here](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Updating-your-SDK.md) to get a copy. ## Some native console programs don't work when run from Git Bash. How to fix it? @@ -84,7 +84,7 @@ There are several methods for working around these problems: * Install and use [ConEmu](https://conemu.github.io/). ## I get errors trying to check out files with long path names. -Windows file paths are by default limited to 260 characters. Some repositories may have committed files which contain paths longer than the limit. By default, *Git for Windows* does not support long paths, and will print errors when trying to perform any operation on a long file name. Set the configuration property `core.longpaths` to true to allow certain Git operations to properly handle these files. See [this wiki page](https://github.com/git-for-windows/git/wiki/Git-cannot-create-a-file-or-directory-with-a-long-path) for more information. +Windows file paths are by default limited to 260 characters. Some repositories may have committed files which contain paths longer than the limit. By default, *Git for Windows* does not support long paths, and will print errors when trying to perform any operation on a long file name. Set the configuration property `core.longpaths` to true to allow certain Git operations to properly handle these files. See [this wiki page](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Git-cannot-create-a-file-or-directory-with-a-long-path.md) for more information. ## The installed files are duplicated and look massive - Why? All the apparent copies are simply hard links - see Issue 1997 [Use symbolic links for libexec](https://github.com/git-for-windows/git/issues/1997) for more details. diff --git a/Documentation/git-for-windows/Git-wrapper.md b/Documentation/git-for-windows/Git-wrapper.md index 172f518a7469b1..882a7da3b123d1 100644 --- a/Documentation/git-for-windows/Git-wrapper.md +++ b/Documentation/git-for-windows/Git-wrapper.md @@ -18,7 +18,7 @@ The actual programs, e.g. `bash.exe` or `git.exe`, live in `\usr\bin` and ` - **`MSYSTEM`** - To accommodate Git's expectations where it assumes e.g. a Unix shell to be present on the `PATH`, Git for Windows ships with a subset of [MSYS2](https://msys2.github.io/) (find out about more historical context [here](https://github.com/git-for-windows/git/wiki#about)). MSYS2 can be run in two flavors, [MINGW and MSYS](https://github.com/git-for-windows/git/wiki/The-difference-between-MINGW-and-MSYS2) and the flavor Git for Windows needs is MINGW. This is specified via the `MSYSTEM` variable. + To accommodate Git's expectations where it assumes e.g. a Unix shell to be present on the `PATH`, Git for Windows ships with a subset of [MSYS2](https://msys2.github.io/) (find out about more historical context [here](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Home.md#about)). MSYS2 can be run in two flavors, [MINGW and MSYS](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/The-difference-between-MINGW-and-MSYS2.md) and the flavor Git for Windows needs is MINGW. This is specified via the `MSYSTEM` variable. - **`PLINK_PROTOCOL`** diff --git a/Documentation/git-for-windows/Home.md b/Documentation/git-for-windows/Home.md index ad4d98b4111da2..f30973919719e6 100644 --- a/Documentation/git-for-windows/Home.md +++ b/Documentation/git-for-windows/Home.md @@ -1,5 +1,5 @@ # Introduction -The _Git for Windows_ wiki. It looks more technical than [our home page](https://gitforwindows.org/) because it is the place where *you* [can contribute](https://github.com/git-for-windows/git/wiki/How-to-participate) to the documentation about _Git for Windows_. +The _Git for Windows_ wiki. It looks more technical than [our home page](https://gitforwindows.org/) because it is the place where *you* [can contribute](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/How-to-participate.md) to the documentation about _Git for Windows_. ## About _Git for Windows_ is very different from _Git_ in one very important respect: As Windows does not provide the *POSIX* infrastructure Git expects, Git for Windows always had to ship with much more than any other Git distribution: provide a `bash`, a `perl`, many *POSIX* tools such as `sed`, `awk`, `tr`, etc. @@ -18,7 +18,7 @@ And yes, the idea is still the same as the original one: Update the _MSYS2_ setu Now, keep in mind that _MSYS2_ and Linux (The original target for _Git_'s distribution) are very different beasts. Their distributions might include packages that are built from the same source code (i.e. the `binutils`, `gcc` or `bash` package), but the runtime is very, very different: _MSYS2_'s runtime is a stripped-down, slightly modified _Cygwin_ runtime running on top of the Windows kernel, while Linux' runtime is the Linux kernel, running as a separate OS altogether. -So if you are missing some packages - feel free to start making one. This is Open Source, after all, so everybody interested and capable enough can contribute whatever they need to address their needs. And that includes you: you could imitate e.g. [a simple `PKGBUILD` file](https://github.com/msys2/MINGW-packages/blob/HEAD/mingw-w64-assimp/PKGBUILD) to build a new package e.g. `msmtp`, the component that _Git for Windows_ 1.x uses to support `sendemail`. Then open a Pull Request so that _Git for Windows_ can ship it. Our documentation will be helpful in that endeavor: [package-management](https://github.com/git-for-windows/git/wiki/Package-management), in particular [package-management#rebuild-packages](https://github.com/git-for-windows/git/wiki/Package-management#rebuild-packages). +So if you are missing some packages - feel free to start making one. This is Open Source, after all, so everybody interested and capable enough can contribute whatever they need to address their needs. And that includes you: you could imitate e.g. [a simple `PKGBUILD` file](https://github.com/msys2/MINGW-packages/blob/HEAD/mingw-w64-assimp/PKGBUILD) to build a new package e.g. `msmtp`, the component that _Git for Windows_ 1.x uses to support `sendemail`. Then open a Pull Request so that _Git for Windows_ can ship it. Our documentation will be helpful in that endeavor: [package-management](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Package-management.md), in particular [package-management#rebuild-packages](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Package-management.md#rebuild-packages). # Start documenting If you need inspiration what you could write about: document your common work flows. Write a tutorial how to start coding _Git for Windows_, how to run the test suite. Write a tutorial how to debug a failing test. Write about something you would have wished you had known about Git for Windows a long time ago. diff --git a/Documentation/git-for-windows/How-to-participate.md b/Documentation/git-for-windows/How-to-participate.md index 18136d74b349cf..ed98c4ff58f358 100644 --- a/Documentation/git-for-windows/How-to-participate.md +++ b/Documentation/git-for-windows/How-to-participate.md @@ -6,14 +6,14 @@ On [the mailing list](http://groups.google.com/group/git-for-windows) or on [the # Add documentation -A lot of documentation wants to be written, still. A good place is [the Git for Windows wiki](https://github.com/git-for-windows/git/wiki). Tutorials, step by step instructions and general background information, etc. Even just keep the links up to date and reporting inconsistencies is helpful. +A lot of documentation wants to be written, still. A good place is [the Git for Windows wiki](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Home.md). Tutorials, step by step instructions and general background information, etc. Even just keep the links up to date and reporting inconsistencies is helpful. # Fix bugs or add features in the Git code itself Download [the SDK](https://gitforwindows.org/#download-sdk) and build Git. See the [CONTRIBUTING.md](https://github.com/git-for-windows/git/blob/HEAD/CONTRIBUTING.md) page/file -Also have a look at [this page](https://github.com/git-for-windows/git/wiki/Building-Git) for tips and tricks revolving around building and debugging Git. +Also have a look at [this page](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Building-Git.md) for tips and tricks revolving around building and debugging Git. Please also sign off your work, as [asked by the Git project](https://git-scm.com/docs/SubmittingPatches#sign-off) diff --git a/Documentation/git-for-windows/Install-or-update-inside-MSYS2,-Cygwin-or-Git-for-windows-itself.md b/Documentation/git-for-windows/Install-or-update-inside-MSYS2,-Cygwin-or-Git-for-windows-itself.md index 5c132923b198fb..ce513c7ffe5b0a 100644 --- a/Documentation/git-for-windows/Install-or-update-inside-MSYS2,-Cygwin-or-Git-for-windows-itself.md +++ b/Documentation/git-for-windows/Install-or-update-inside-MSYS2,-Cygwin-or-Git-for-windows-itself.md @@ -1,4 +1,4 @@ -## It's different from [Install inside MSYS2 proper](https://github.com/git-for-windows/git/wiki/Install-inside-MSYS2-proper) +## It's different from [Install inside MSYS2 proper](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Install-inside-MSYS2-proper.md) Instead of configuring and installing Git for Windows using `pacman`, this guide introduces another approach to properly install or update Git for Windows inside MSYS2, Cygwin or even Git for Windows itself. The only thing you need is a `bash` interpreter on Windows and a `curl`. diff --git a/Documentation/git-for-windows/Making-a-portable-Git.md b/Documentation/git-for-windows/Making-a-portable-Git.md index e8431f0be8d711..e8f5e43e2f4d9c 100644 --- a/Documentation/git-for-windows/Making-a-portable-Git.md +++ b/Documentation/git-for-windows/Making-a-portable-Git.md @@ -1,4 +1,4 @@ -As the portable Git is made by putting together files from the Git SDK, it is advisable to update those files first. To update the packages, call `pacman -Syu` ([caveats apply](https://github.com/git-for-windows/git/wiki/Package-management#updating-msys2-runtime-pacman-and-bash)). If you want to test Git changes or make an portable Git from your own Git fork, you need to call `cd /usr/src/git && make install` (for documentation changes, `make install-html` and *afterwards* `prefix=/mingw64 make -C contrib/subtree install-html` - without the second `make` you get a error message about a missing `git-subtree.html` file). +As the portable Git is made by putting together files from the Git SDK, it is advisable to update those files first. To update the packages, call `pacman -Syu` ([caveats apply](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Package-management.md#updating-msys2-runtime-pacman-and-bash)). If you want to test Git changes or make an portable Git from your own Git fork, you need to call `cd /usr/src/git && make install` (for documentation changes, `make install-html` and *afterwards* `prefix=/mingw64 make -C contrib/subtree install-html` - without the second `make` you get a error message about a missing `git-subtree.html` file). To package the portable Git, install the [SDK](https://gitforwindows.org/#download-sdk), run it and then issue the following commands: diff --git a/Documentation/git-for-windows/Making-an-installer.md b/Documentation/git-for-windows/Making-an-installer.md index 9941c8acc30a14..dd0da1021512c7 100644 --- a/Documentation/git-for-windows/Making-an-installer.md +++ b/Documentation/git-for-windows/Making-an-installer.md @@ -15,7 +15,7 @@ sdk cd installer # Detailed overview -As the installer is made by putting together files from the Git SDK, it is advisable to update those files first. To update the packages, call `pacman -Syu` ([caveats apply](https://github.com/git-for-windows/git/wiki/Package-management#updating-msys2-runtime-pacman-and-bash)). +As the installer is made by putting together files from the Git SDK, it is advisable to update those files first. To update the packages, call `pacman -Syu` ([caveats apply](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Package-management.md#updating-msys2-runtime-pacman-and-bash)). If you want to test Git changes or make an installer from your own Git fork, you need to call diff --git a/Documentation/git-for-windows/Mapping-between-Git-Installer-GUI-Settings-And-Command-Line-Arguments.md b/Documentation/git-for-windows/Mapping-between-Git-Installer-GUI-Settings-And-Command-Line-Arguments.md index c239635381feba..6e483eac000a17 100644 --- a/Documentation/git-for-windows/Mapping-between-Git-Installer-GUI-Settings-And-Command-Line-Arguments.md +++ b/Documentation/git-for-windows/Mapping-between-Git-Installer-GUI-Settings-And-Command-Line-Arguments.md @@ -17,4 +17,4 @@ The following table maps Git GUI Installation settings to corresponding Git Comm
-For a comprehensive list of Git for Windows Installer command line arguments [see here](https://github.com/git-for-windows/git/wiki/Silent-or-Unattended-Installation). \ No newline at end of file +For a comprehensive list of Git for Windows Installer command line arguments [see here](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Silent-or-Unattended-Installation.md). \ No newline at end of file diff --git a/Documentation/git-for-windows/Merge-Conflicts---Resolving-and-Remembering-them.md b/Documentation/git-for-windows/Merge-Conflicts---Resolving-and-Remembering-them.md index bab4f42a7e8e07..ecfd49aef90530 100644 --- a/Documentation/git-for-windows/Merge-Conflicts---Resolving-and-Remembering-them.md +++ b/Documentation/git-for-windows/Merge-Conflicts---Resolving-and-Remembering-them.md @@ -2,7 +2,7 @@ Work in Progress as I try and work out how to do this (06-04-2019).. When building a new release for Git-for-Windows, the full range of Windows patches the maintainer applies need to be moved ([`rebase`](https://git-scm.com/docs/git-rebase)d) from being on top of the old upstream Git, to being on top of the new upstream release. -There is a [process](https://github.com/git-for-windows/git/wiki/Rebasing-Git-for-Windows), a script and the support of the merging-rebase code, but still there maybe conflicts, old and new, especially if some of the Windows code has been adopted upstream in a different form. +There is a [process](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Rebasing-Git-for-Windows.md), a script and the support of the merging-rebase code, but still there maybe conflicts, old and new, especially if some of the Windows code has been adopted upstream in a different form. This note looks at how to remember those resolutions, reuse them, and to learn from previous Git-for-Windows rebases. The magic is in the [REuse REcorded REsolution (rerere)](https://git-scm.com/docs/git-rerere) command and it's underlying database. diff --git a/Documentation/git-for-windows/Rebasing-Git-for-Windows.md b/Documentation/git-for-windows/Rebasing-Git-for-Windows.md index 3380ffb928f076..3bf7b6fd0e0e83 100644 --- a/Documentation/git-for-windows/Rebasing-Git-for-Windows.md +++ b/Documentation/git-for-windows/Rebasing-Git-for-Windows.md @@ -25,7 +25,7 @@ Run the `shears.sh` script to build up the actual *rebase* script. Note: `v2.3.4` is a `tag` in the remote `git`. See the script if you are testing changes initiated in a local branch of the git upstream. -The *rebase* should start automatically and occasionally stop if it hits any merge conflicts. Resolve those conflicts (see also [Merge Conflicts Resolving and Remembering them](https://github.com/git-for-windows/git/wiki/Merge-Conflicts---Resolving-and-Remembering-them)) and then continue the rebase. +The *rebase* should start automatically and occasionally stop if it hits any merge conflicts. Resolve those conflicts (see also [Merge Conflicts Resolving and Remembering them](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Merge-Conflicts---Resolving-and-Remembering-them.md)) and then continue the rebase. `git rebase --continue` Note: the `merging-rebase` argument is a special placeholder that is interpreted by the `shears.sh` script to find the commit that started the previous merging-rebase. You can find the commit yourself like this: diff --git a/Documentation/git-for-windows/Technical-overview.md b/Documentation/git-for-windows/Technical-overview.md index ea47f3e2de7708..61eb434fab3aec 100644 --- a/Documentation/git-for-windows/Technical-overview.md +++ b/Documentation/git-for-windows/Technical-overview.md @@ -12,25 +12,25 @@ Download the [SDK](https://gitforwindows.org/#download-sdk) and run it (using "R You can open the `Git for Windows SDK` shell by double clicking `git-bash.exe` in the install folder. -As the installer is made by putting together files from the Git for Windows SDK, it is advisable to update those files first. To update the packages, call `pacman -Syu` ([caveats apply](https://github.com/git-for-windows/git/wiki/Package-management#updating-msys2-runtime-pacman-and-bash)). +As the installer is made by putting together files from the Git for Windows SDK, it is advisable to update those files first. To update the packages, call `pacman -Syu` ([caveats apply](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Package-management.md#updating-msys2-runtime-pacman-and-bash)). # Hacking on git If you only want an installer of the latest development version of git, then you can skip this step. -The sources of git are checked out in `/usr/src/git`. [Hack in (and test)](Building-Git) the changes you want... +The sources of git are checked out in `/usr/src/git`. [Hack in (and test)](Building-Git.md) the changes you want... Afterwards you need to install git to make these changes available to the installer build: `cd /usr/src/git && make install`. If you made any documentation changes, you need to install the documentation too: `make install-html && prefix=/mingw64 make -C contrib/subtree install-html` (the second make invocation installs the `git-subtree.html` which is otherwise missing and leads to an error by the portable installer). -In some cases, the change you want to make is not in git itself, but in the additional files needed to emulate the *ix environment git expects (things like `grep`, `find`, `cat`,...), or in additional helper files (e.g. `start-ssh-agent.cmd`). These files come from [Msys](https://github.com/git-for-windows/MSYS2-packages) and [Mingw](https://github.com/git-for-windows/MINGW-packages) packages. Please see the documentation for how to make [changes to these packages](Package-management#technical-details). Some files are also in the `build-extras` repo in the subdir [`mingw-w64-git-extra`](https://github.com/git-for-windows/build-extra/tree/HEAD/mingw-w64-git-extra) (the script which calls notepad as a commit message editor, diff filter for word files,...). The source code for these files are also under `/usr/src` but need to be checked out first (e.g. `cd /usr/src/MINGW-packages && git fetch && git checkout main`). +In some cases, the change you want to make is not in git itself, but in the additional files needed to emulate the *ix environment git expects (things like `grep`, `find`, `cat`,...), or in additional helper files (e.g. `start-ssh-agent.cmd`). These files come from [Msys](https://github.com/git-for-windows/MSYS2-packages) and [Mingw](https://github.com/git-for-windows/MINGW-packages) packages. Please see the documentation for how to make [changes to these packages](Package-management.md#technical-details). Some files are also in the `build-extras` repo in the subdir [`mingw-w64-git-extra`](https://github.com/git-for-windows/build-extra/tree/HEAD/mingw-w64-git-extra) (the script which calls notepad as a commit message editor, diff filter for word files,...). The source code for these files are also under `/usr/src` but need to be checked out first (e.g. `cd /usr/src/MINGW-packages && git fetch && git checkout main`). # Building an installer You can build both a normal setup installer and a portable one. -The installers are basically created by collecting files from the `Git for Windows SDK` Msys environment, not from any checked out source code! It's therefore important to make any changed files available to the installer (the `make` calls in the "[Hacking on git](https://github.com/git-for-windows/git/wiki/Technical-overview#hacking-on-git)" step)! +The installers are basically created by collecting files from the `Git for Windows SDK` Msys environment, not from any checked out source code! It's therefore important to make any changed files available to the installer (the `make` calls in the "[Hacking on git](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Technical-overview.md#hacking-on-git)" step)! As a one time step, you need to prepare the extra files which contain the helper scripts: @@ -57,8 +57,8 @@ To build a portable installer, use: The last line of the log shows where the installer packages were created (usually in your user directory: `c:\Users\ `). See also: -* [Debugging git](Debugging-Git) with gdb -* Running Git's [regression tests](Running-Git's-regression-tests) -* MSYS/MINGW [package management](Package-management#technical-details) -* [Updating the SDK](https://github.com/git-for-windows/git/wiki/Updating-your-SDK) +* [Debugging git](Debugging-Git.md) with gdb +* Running Git's [regression tests](Running-Git%27s-regression-tests.md) +* MSYS/MINGW [package management](Package-management.md#technical-details) +* [Updating the SDK](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Updating-your-SDK.md) * [MSYS2](https://msys2.github.io/) diff --git a/Documentation/git-for-windows/The-difference-between-MINGW-and-MSYS2.md b/Documentation/git-for-windows/The-difference-between-MINGW-and-MSYS2.md index c4c8cb699941cf..3ff99770ea6c72 100644 --- a/Documentation/git-for-windows/The-difference-between-MINGW-and-MSYS2.md +++ b/Documentation/git-for-windows/The-difference-between-MINGW-and-MSYS2.md @@ -36,7 +36,7 @@ Now, to understand the packages' names better, we need to understand how MSYS2 p MSYS2's runtime is `\usr\bin\msys-2.0.dll`. It is an implicit dependency of all MSYS2 executables (most of which live in \usr\bin). This runtime provides emulation for all POSIX functionality enjoyed e.g. by Linux software. This means that it is *a lot* easier to port Linux projects to MSYS2 than it is to straight Windows. So when porting Bash or OpenSSH, it is much, much easier to port them to an MSYS2 package. So why don't we just make all packages MSYS2 ones? The POSIX emulation is *slow*. Like, really, really noticeably slow. -So it is much preferred to port Linux software to pure Win32 calls, without going the POSIX emulation route. Of course, this is a ton more work *per project*. That is the reason why this is not done for all packages. You may want to read [this article](https://github.com/git-for-windows/git/wiki/Windows-vs-Linux-fork()/exec()-semantics) for getting an acquaintance of just a part of underlying problems. +So it is much preferred to port Linux software to pure Win32 calls, without going the POSIX emulation route. Of course, this is a ton more work *per project*. That is the reason why this is not done for all packages. You may want to read [this article](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Windows-vs-Linux-fork%28%29/exec%28%29-semantics.md) for getting an acquaintance of just a part of underlying problems. Normally, we use Visual C++ compiler on Windows. When building Windows software using GCC, it is necessary to have all the support headers and libraries. They are not provided by Microsoft, but by a separate project called MINGW ("Minimal GNU on Windows"). MSYS2 uses these MINGW libraries (and MINGW GCC compiler) to build pure Win32 packages, and those are called MINGW packages. diff --git a/Documentation/git-for-windows/Updating-your-SDK.md b/Documentation/git-for-windows/Updating-your-SDK.md index c1ec86331c9c08..23f5107300581d 100644 --- a/Documentation/git-for-windows/Updating-your-SDK.md +++ b/Documentation/git-for-windows/Updating-your-SDK.md @@ -63,7 +63,7 @@ One option is a re-install, having saved your working repositories. ### See Also: -* [G4W Package Management](https://github.com/git-for-windows/git/wiki/Package-management) +* [G4W Package Management](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Package-management.md) * [pacman man page](https://www.archlinux.org/pacman/pacman.8.html) * [PKGBuild man page](https://www.archlinux.org/pacman/PKGBUILD.5.html) * [makepkg man page](https://www.archlinux.org/pacman/makepkg.8.html) diff --git a/Documentation/git-for-windows/Upgrading-the-`perl`-component-to-a-new-version.md b/Documentation/git-for-windows/Upgrading-the-`perl`-component-to-a-new-version.md index 74838dd6787c7e..67f428d8214ce8 100644 --- a/Documentation/git-for-windows/Upgrading-the-`perl`-component-to-a-new-version.md +++ b/Documentation/git-for-windows/Upgrading-the-`perl`-component-to-a-new-version.md @@ -1,10 +1,10 @@ One of the many components included in Git for Windows' SDK is the `perl` package. Part of its components are included in Git for Windows' installer and Portable Git versions, to allow for running Perl scripts. The two most prominent Perl scripts in Git for Windows are, of course, `git svn` and `git send-email`. -Upgrading to a new Perl version is unfortunately a bit more involved than only following the advice in [Building new package versions](Building-new-package-versions). In addition to adjusting the patches applied via the `PKGBUILD` script, the major problem with Perl is that its DLL embeds the Perl version in its file name. +Upgrading to a new Perl version is unfortunately a bit more involved than only following the advice in [Building new package versions](Building-new-package-versions.md). In addition to adjusting the patches applied via the `PKGBUILD` script, the major problem with Perl is that its DLL embeds the Perl version in its file name. # Making sure that the DLL has the correct version in its file name -This is important, and it is a manual step required on top of [the usual adjustments to the patches](https://github.com/git-for-windows/git/wiki/Building-new-package-versions#adjusting-patches-when-they-no-longer-apply-to-new-versions): In the [`PKGBUILD`](https://github.com/msys2/MSYS2-packages/blob/HEAD/perl/PKGBUILD) file, the line `-Dlibperl=msys-perl5_.dll` needs to be adjusted. +This is important, and it is a manual step required on top of [the usual adjustments to the patches](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/Building-new-package-versions.md#adjusting-patches-when-they-no-longer-apply-to-new-versions): In the [`PKGBUILD`](https://github.com/msys2/MSYS2-packages/blob/HEAD/perl/PKGBUILD) file, the line `-Dlibperl=msys-perl5_.dll` needs to be adjusted. # Rebuilding dependencees diff --git a/Documentation/git-for-windows/Visual-Studio-and-MSVC-compilation.md b/Documentation/git-for-windows/Visual-Studio-and-MSVC-compilation.md index 856dc8a69c2215..4df4ec9a28cb18 100644 --- a/Documentation/git-for-windows/Visual-Studio-and-MSVC-compilation.md +++ b/Documentation/git-for-windows/Visual-Studio-and-MSVC-compilation.md @@ -29,7 +29,7 @@ This is the environment variable used to indicate that this is not a CYGWIN comp see https://blogs.msdn.microsoft.com/oldnewthing/20091130-00/?p=15863 This controls what additional libraries windows will import, particularly winsock which would otherwise be multiply defined. ### MSYS2 -part of the (typically needed) operating stack for getting *nix / POSIX code working. see [The-difference-between-MINGW-and-MSYS2](https://github.com/git-for-windows/git/wiki/The-difference-between-MINGW-and-MSYS2) +part of the (typically needed) operating stack for getting *nix / POSIX code working. see [The-difference-between-MINGW-and-MSYS2](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/The-difference-between-MINGW-and-MSYS2.md) ### MinGW -part of the (typically needed) operating stack for getting *nix / POSIX code working. see [The-difference-between-MINGW-and-MSYS2](https://github.com/git-for-windows/git/wiki/The-difference-between-MINGW-and-MSYS2) +part of the (typically needed) operating stack for getting *nix / POSIX code working. see [The-difference-between-MINGW-and-MSYS2](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/The-difference-between-MINGW-and-MSYS2.md) diff --git a/Documentation/git-for-windows/Windows-vs-Linux-fork()/exec()-semantics.md b/Documentation/git-for-windows/Windows-vs-Linux-fork()/exec()-semantics.md index e14449719ca007..03745711f84592 100644 --- a/Documentation/git-for-windows/Windows-vs-Linux-fork()/exec()-semantics.md +++ b/Documentation/git-for-windows/Windows-vs-Linux-fork()/exec()-semantics.md @@ -9,7 +9,7 @@ Note that there's a newer, single call method on Linux ([`posix_spawn()`](http:/ All information about Linux is a brief retelling of Robert Love's book: [Linux Kernel Development](https://doc.lagout.org/operating%20system%20/linux/Linux%20Kernel%20Development%2C%203rd%20Edition.pdf). I definitely recommend you to read this book by yourself, especially if this article wasn't enough for you. I will oversimplify, otherwise I'd need to put the whole book here. -`fork()` on Windows is emulated by *MSYS*, while there is no `fork()` in *MINGW*. That is partially what makes [MSYS much slower than MINGW](https://github.com/git-for-windows/git/wiki/The-difference-between-MINGW-and-MSYS2). +`fork()` on Windows is emulated by *MSYS*, while there is no `fork()` in *MINGW*. That is partially what makes [MSYS much slower than MINGW](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/The-difference-between-MINGW-and-MSYS2.md). # Copy-on-write @@ -23,4 +23,4 @@ Since this scenario is so common on Linux, the system is optimized to execute `f # Windows internals: why fork() does not work as native -Windows doesn't officially have a good substitute of neither `fork()` nor `exec()`, so some smart people made a replacement that works pretty well, but can't be optimized well because it doesn't work at the system level. The replacement works like this: By calling `fork()`, the original process creates a process from the same executable, but it's like brand new at this point, as if it had no connection to the original one. Then the new process realizes it is supposed to be a fork and copies the entire address accessible memory space of the original process. It tries as best as it can to open the original file descriptors and sockets. It reinstates the current working directory (even if it does not exist anymore) and more. It spends a whole lot of time making sure the fork is as perfect as it can be [and may even fail completely when it can't due to DLL preloading](https://github.com/git-for-windows/git/wiki/32-bit-issues). Then the new process calls `exec()`, throws out all this and finally creates a new process with the correct executable. +Windows doesn't officially have a good substitute of neither `fork()` nor `exec()`, so some smart people made a replacement that works pretty well, but can't be optimized well because it doesn't work at the system level. The replacement works like this: By calling `fork()`, the original process creates a process from the same executable, but it's like brand new at this point, as if it had no connection to the original one. Then the new process realizes it is supposed to be a fork and copies the entire address accessible memory space of the original process. It tries as best as it can to open the original file descriptors and sockets. It reinstates the current working directory (even if it does not exist anymore) and more. It spends a whole lot of time making sure the fork is as perfect as it can be [and may even fail completely when it can't due to DLL preloading](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/32-bit-issues.md). Then the new process calls `exec()`, throws out all this and finally creates a new process with the correct executable. diff --git a/README.md b/README.md index 4eabce53d89e1f..ce897d4145cf21 100644 --- a/README.md +++ b/README.md @@ -15,7 +15,7 @@ encounter problems, you can report them as [GitHub issues](https://github.com/git-for-windows/git/issues), discuss them on Git for Windows' [Google Group](http://groups.google.com/group/git-for-windows), and [contribute bug -fixes](https://github.com/git-for-windows/git/wiki/How-to-participate). +fixes](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/How-to-participate.md). To build Git for Windows, please either install [Git for Windows' SDK](https://gitforwindows.org/#download-sdk), start its `git-bash.exe`, `cd` diff --git a/SECURITY.md b/SECURITY.md index 328351684298a4..ef2914677f69c2 100644 --- a/SECURITY.md +++ b/SECURITY.md @@ -32,7 +32,7 @@ Git for Windows is a "friendly fork" of [Git](https://git-scm.com/), i.e. change While Git maintains several release trains (when v2.19.1 was released, there were updates to v2.14.x-v2.18.x, too, for example), Git for Windows follows only the latest Git release. For example, there is no Git for Windows release corresponding to Git v2.16.5 (which was released after v2.19.0). -One exception is [MinGit for Windows](https://github.com/git-for-windows/git/wiki/MinGit) (a minimal subset of Git for Windows, intended for bundling with third-party applications that do not need any interactive commands nor support for `git svn`): critical security fixes are backported to the v2.11.x, v2.14.x, v2.19.x, v2.21.x and v2.23.x release trains. +One exception is [MinGit for Windows](https://github.com/git-for-windows/git/blob/HEAD/Documentation/git-for-windows/MinGit.md) (a minimal subset of Git for Windows, intended for bundling with third-party applications that do not need any interactive commands nor support for `git svn`): critical security fixes are backported to the v2.11.x, v2.14.x, v2.19.x, v2.21.x and v2.23.x release trains. ## Version number scheme From 22f4e6afb31a27ec62059a7173c161063a30494d Mon Sep 17 00:00:00 2001 From: Johannes Schindelin Date: Wed, 15 May 2024 21:43:37 +0200 Subject: [PATCH 591/591] Mention the newest security bug-fix release --- FAQ.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/FAQ.md b/FAQ.md index 6097d3f0d6e7de..b1f8385dd86451 100644 --- a/FAQ.md +++ b/FAQ.md @@ -31,7 +31,7 @@ In the meantime you could try: In general, yes: it is a good idea to stay up-to-date. -If you have a version older than 2.40.1, it is *highly* advisable to upgrade. A couple of Git versions came with important fixes to security-relevant vulnerabilities: 2.40.1, 2.39.2, 2.39.1, 2.38.1, 2.37.1, 2.36.0, 2.35.3, 2.35.3, 2.30.2, 2.30.0(2), 2.29.2(3), 2.29.2(2), 2.26.1, 2.24.1(2), 2.17.1(2), 2.14.1, 2.7.4, 2.7.0, 2.6.1, 2.5.2, 1.9.5-preview20150319, and 1.9.5-preview20141217. +If you have a version older than 2.45.1, it is *highly* advisable to upgrade. A couple of Git versions came with important fixes to security-relevant vulnerabilities: 2.45.1, 2.40.1, 2.39.2, 2.39.1, 2.38.1, 2.37.1, 2.36.0, 2.35.3, 2.35.3, 2.30.2, 2.30.0(2), 2.29.2(3), 2.29.2(2), 2.26.1, 2.24.1(2), 2.17.1(2), 2.14.1, 2.7.4, 2.7.0, 2.6.1, 2.5.2, 1.9.5-preview20150319, and 1.9.5-preview20141217. ## How do I update *Git for Windows* upon new releases?