-
Notifications
You must be signed in to change notification settings - Fork 2.7k
Building Git
We build Git for Windows using MSys2.
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.
-
Install MSys2 from https://msys2.github.io/, into
C:/msys32
andC:/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. -
Download and run this file in a
cmd
window in the top-level MSys2 directory (you need to close all MSys2 windows before that, so that themsys-2.0.dll
file can be updated).
-
Clone Git:
cd /usr/src/ && git clone https://github.com/git-for-windows/git
. -
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
. -
Build Git:
make
. -
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 post, in short: close all MSys2 windows and run the autorebase.bat
script in the top-level MSys2 directory from a cmd
.
-
Install the MSys2 Toolchain:
pacman -S gcc binutils make
. -
Clone the MSYS2-packages repository:
cd /usr/src && git clone https://github.com/git-for-windows/MSYS2-packages
. -
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
. -
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.)
This wiki page has been retired. All it did was to point to Git for Windows' governance model.