- Install Visual Studio (any edition will work fine). Select at minimum the following components:
- C++ core features
- IntelliCode
- Windows Universal C Runtime
- Windows Universal CRT SDK
- C++ build tools (x86 & x64)
- C++ ATL
- C++ MFC
- Windows 10 SDK (10.0.17763.0 or any other version)
- Install the Windows 8.1 SDK → https://go.microsoft.com/fwlink/p/?LinkId=323507
- When choosing which features to install you only need to select "Windows Software Development Kit".
- Alternatively you can use Windows 10 SDK, but then resulting binaries will require at least Windows 7 SP1, so you lose compatibility with Vista and 7 RTM.
This is required for building the translation DLL files.
- Install Python version 3.8.7 from https://www.python.org/downloads/release/python-387/ (You can use Python 3.6 or later version)
- Run this command to install a required library:
C:\Program Files\Python38\Scripts\pip install --upgrade polib
This is required for building LAV Filters, which is used as the internal codecs by MPC-HC.
You can skip compilation of LAV Filters by selecting the "Release Lite"/"Debug Lite" build configuration in the MPC-HC project file. This can be useful for making quick builds during development. The resulting binary will be missing the internal filter functionality. So don't use this configuration for actual releases.
- Download MSYS2 from http://www.msys2.org/. If you are using a 64-bit Operating System, which you should be, get the 64-bit version.
- Install it to for example
C:\MSYS64\
. The installation path should be specified in your build.user.bat configuration script that you will create later. - Run
msys2_shell.bat
- Install some additional required tools by running this command:
pacman -S make pkg-config diffutils
- Then update all packages by running this command:
When you are asked to restart MSYS, say yes. Start MSYS again and repeat the above command. Once everything is updated, you can close MSYS.
pacman -Syu
- Download the latest mingw-w64-gcc package from http://files.1f0.de/mingw/ and extract it to folder
C:\MSYS64\mingw64
(overwriting any existing files). - It is recommended to add
C:\MSYS64\mingw64\bin
andC:\MSYS64\usr\bin
to the %PATH% environment variable. This allows you to run GCC and all other MSYS tools from the Windows command line.
Windows Control Panel > System > Advanced System Settings > Environment variables.
On Windows 10 you can access the legacy control panel by clicking on the Windows Start menu and typingcontrol.exe
.
Download YASM and save it as yasm.exe in a folder that is included in %PATH%. For example C:\Windows
or C:\MSYS64\usr\bin
(see part C).
- For 64-bit Windows: http://www.tortall.net/projects/yasm/releases/yasm-1.3.0-win64.exe (Recommended)
- For 32-bit Windows: http://www.tortall.net/projects/yasm/releases/yasm-1.3.0-win32.exe
Create a file named build.user.bat in the source code folder of MPC-HC (see part F). It should have the following contents: (with paths adapted for your system!)
@ECHO OFF
REM [Required for LAVFilters] MSYS2/MinGW paths:
SET "MPCHC_MSYS=C:\MSYS64"
SET "MPCHC_MINGW32=C:\MSYS64\mingw64"
SET "MPCHC_MINGW64=C:\MSYS64\mingw64"
SET "MSYSTEM=MINGW32"
SET "MSYS2_PATH_TYPE=inherit"
REM [Optional] Specify GIT location if it is not already set in %PATH%
SET "MPCHC_GIT=C:\Program Files\Git"
REM [Optional] If you plan to modify the translations, install Python 3.8 and set the variable to its path
SET "MPCHC_PYTHON=C:\Program Files\Python38"
REM [Optional] If you want to customize the Windows SDK version used, set this variable
SET "MPCHC_WINSDK_VER=8.1"
Notes:
- For Visual Studio, we will try to detect the VS installation path automatically. If that fails you need to specify the installation path yourself. For example:
SET "MPCHC_VS_PATH=%ProgramFiles(x86)%\Microsoft Visual Studio\2019\Community\"
- If you installed the MSYS package in another directory then make sure that you have set the correct paths in your build.user.bat file.
- If you don't have Git installed then the build version will be inaccurate, the revision number will be a hard-coded as zero.
You need Git for downloading the source code.
Install Git for Windows from https://git-for-windows.github.io/ and also Git Extensions from http://gitextensions.github.io/.
Choose Use Git from the Windows command prompt
. This isn't mandatory, so if you choose
Use Git from Git Bash only
make sure you set the MPCHC_GIT
variable in build.user.bat.
Use Git to clone MPC-HC's repository to C:\mpc-hc (or anywhere else you like).
-
Install Git
-
Run these commands:
git clone --recursive https://github.com/clsid2/mpc-hc.git
or
git clone https://github.com/clsid2/mpc-hc.git git submodule update --init --recursive
If a submodule update fails, try running:
git submodule foreach --recursive git fetch --tags
then run the update again
git submodule update --init --recursive
Note that you can add -b master
to the git clone
command if you want to get the latest
stable version instead of the latest development version.
- Download NASM from https://www.nasm.us/pub/nasm/releasebuilds/2.14.02/nasm-2.14.02.zip
- Put nasm.exe in the VC folder of your Visual Studio intallation. Example: C:\Program Files (x86)\Microsoft Visual Studio\2019\Community\VC
- Open the solution file C:\mpc-hc\mpc-hc.sln. Change the solution's configuration to Release (in the toolbar).
- Press F7 to build the solution.
- You now have mpc-hc.exe under C:\mpc-hc\bin\mpc-hc_x86
- Open the solution file C:\mpc-hc\mpciconlib.sln
- Press F7 to build the solution.
- You now have mpciconlib.dll under C:\mpc-hc\bin\mpc-hc_x86
- Open the solution file C:\mpc-hc\mpcresources.sln
- Build BuildAll project.
- You now have mpcresources.XX.dll under C:\mpc-hc\bin\mpc-hc_x86\Lang
Alternatively, you can use build.bat that can build everything for you (run: build.bat help
for more info).
Download Inno Setup Unicode v5.5.9 or newer from http://www.jrsoftware.org/isdl.php. Install everything and then go to C:\mpc-hc\distrib, open mpc-hc_setup.iss with Inno Setup, read the first comments in the script and compile it.
- build.bat can build the installer by using the installer or the packages switch.
- Use Inno Setup's built-in IDE if you want to edit the iss file and don't change its encoding since it can break easily.