The steps of using MSYS and MinGW/MinGW-w64 are quite similar to MSYS2 so I will only write about how to use MSYS2 to build Qt from source code.
- Download MSYS2 from it's official website (http://www.msys2.org/) and install it.
- Run MSYS2 shell command prompt (default location: "C:\msys64\msys2_shell.cmd" -msys)
- Update MSYS2 core components (if you have not done it yet):
pacman -Syu
- Exit out from MSYS2-shell (just close the shell window forcely), restart MSYS2-shell, then run below command, to complete rest of other components update:
pacman -Su
- Exit out of MSYS2-shell, restart MSYS2-shell, then you are ready to use MSYS2-shell.
Note
For MSYS and MinGW/MinGW-w64, just download the latest packages and extract them to anywhere you like. If an installation is needed, you will have to install it, of course. And remember to add their binaries' paths to your system PATH variable.
-
If you want to use ANGLE or if you want Qt to load OpenGL dynamically, download Microsoft DirectX SDK June 2010 from it's official website (http://www.microsoft.com/en-us/download/details.aspx?id=6812) and install it. You have to install this version of DirectX SDK, the newest DirectX SDK inside the Windows 10 SDK is not supported.
-
Start MSYS2-shell. Run/execute below commands to load MinGW-w64 SEH (64bit/x86_64) posix and Dwarf-2 (32bit/i686) posix toolchains & related other tools, dependencies & components from MSYS2 REPO:
pacman -S base-devel git mercurial cvs wget p7zip pacman -S perl ruby python2 mingw-w64-i686-toolchain mingw-w64-x86_64-toolchain
Notes
- The i686 (32bit) toolchain loads into "/c/msys64/mingw32/bin" ("C:\msys64\mingw32\bin") directory location, and, x86_64 (64bit) toolchain loads into "/c/msys64/mingw64/bin" ("C:\msys64\mingw64\bin") directory. Perl, Ruby, Python, OpenSSL etc loads into "/c/msys64/usr/bin" ("C:\msys64\usr\bin") directory.
- For MSYS and MinGW/MinGW-w64, you will have to download and install these softwares above from their official websites.
- ATTENTION: You need to download and install the latest version of Python 2, not Python 3, because according to Qt official wiki, Python 3 is not supported.
-
Start MSYS2 shell command prompt and run below commands:
cd /c/Qt/Qt5.11.0/src windows2unix() { local pathPcs=() split pathTmp IFS=\;; read -ra split <<< "$*"; for pathTmp in "${split[@],}"; do pathPcs+=( "/${pathTmp//+([:\\])//}" ); done; echo "${pathPcs[*]}"; }; systemrootP=$(windows2unix "$SYSTEMROOT"); export PATH="$PWD/qtbase/bin:$PWD/gnuwin32/bin:/c/msys64/mingw64/bin:/c/msys64/usr/bin:$PATH"
Notes
- Remember to change "/c/Qt/Qt5.11.0/src" to the path of your Qt source code directory and you should change "\" to "/", "C:\" to "/c/", "D:\" to "/d/" (etc) as well.
- For MSYS and MinGW/MinGW-w64, the commands are the same with MSYS2 and remember to add perl, python and ruby's paths to the PATH variable.
-
Run below commands to configure Qt:
./configure -opensource -confirm-license -release -static -skip qtwebengine -platform win32-g++ -opengl dynamic -qt-sqlite -qt-zlib -qt-libjpeg -qt-libpng -qt-freetype -qt-pcre -qt-harfbuzz -nomake examples -nomake tests -prefix $PWD/../dist -silent
Notes
- If you want to build the debug version of Qt, use "-debug" instead of "-release" or if you want to build both debug and release versions of Qt, use "-debug-and-release" instead of "-release".
- If you want to build the shared version of Qt, use "-shared" instead of "-static".
- If you want Qt to load OpenGL dynamically, use "-opengl dynamic" (highly recommended, but need Microsoft DirectX SDK June 2010 to build ANGLE), if you want Qt to use ANGLE only, use "-opengl es2" (Windows only, also need Microsoft DirectX SDK June 2010), if you want Qt to use Desktop OpenGL only, use "-opengl desktop" (no need of ANGLE, so no need of Microsoft DirectX SDK June 2010 as well).
- If you want to build QWebEngine, you have to change your system locale to English(United States) and don't forget to change it back after building Qt.
- According to Qt official wiki, QWebEngine module cannot be compiled statically, so you have skip it using "-skip qtwebengine" when you are building the static version of Qt.
- "-prefix=path" where "path" is the path of the target directory the compiled binaries should be copied to.
- IMPORTANT: "-static-runtime" and "-ltcg" will result in compilation failure, currently I don't know why.
-
If the configuration process above finished successfully, run below commands to build Qt and copy the compiled binaries to the target directory:
make -j n && make install
Note
- "make -j n" where "n" is the number of the CPU cores your PC has.
- Remember to put "qt.conf" and "qtenv2.bat" to the "bin" directory. You can create new files if you cannot find the original files in "src/qtbase/bin".
- For MSYS and MinGW/MinGW-w64, use "mingw32-make" instead of "make".