-
-
Notifications
You must be signed in to change notification settings - Fork 1.3k
Compiling On Windows
(If you're looking to make an installable release, go to this page.)
Note: These instructions are valid for Mixxx 2.3 onwards. Mixxx 2.2 and below used Scons instead of CMake. You will find instructions for that older release in the History of this wiki page.
-
Visual Studio 2019 Community Edition or the Visual Studio 2019 Build Tools.
Follow the installation instructions on that link to setup the compiler and CMake.
'Visual Studio Code' is not suitable for building Mixxx on Windows!
The CMake version that comes with 'Visual Studio 2017' is too old for building Mixxx! -
A Git client like Git for Windows, TortoiseGit (requires Git for Windows to be installed) or the github windows client
Both Git for Windows and github windows feature a unix like command line.
-
This is needed if you want to use sccache when building from commandline.
When Rust is installed, open a console window and type
cargo install --git https://github.com/Be-ing/sccache.git --branch fix_msvc_fp
(Temporarily using a fork to fix an error with the /FP parameter) -
Windows Powershell 5.1 or later
(Windows 10 comes with 5.1) for older Windows releases it need to be downloaded here: https://docs.microsoft.com/en-us/powershell/scripting/windows-powershell/install/installing-windows-powershell?view=powershell-5.1#upgrading-existing-windows-powershell
-
Clone the Mixxx repository.
Remember the folder to which the repository was saved. We will refer to that folder as MIXXX_REPO later.
To build Mixxx, you need built copies of its dependencies. You may download pre-built versions of them from the Mixxx team (recommended) or build them from source.
The easiest option to get the built dependencies is to use the script located in MIXXX_REPO/tools/windows_buildenv.bat.
This script will download the appropriate file from Mixxx servers, and autogenerate a CMakeSettings.json file which can later be used to build Mixxx with the default settings from Visual Studio.
It will download the dependencies to MIXXX_REPO\buildenv\2.3-j00019-x64-release-fastbuild-static-55e94982-minimal We will refer to this folder as WINLIB_PATH later.
Alternatively, you can find links to pre-built Mixxx dependencies at the bottom of this Github Page.
The folder 2.?.x-windows
contains build environments for the 2.?
release of Mixxx. If you are working on the master branch, always pick
the latest version. If you want to work on a specific branch, pick the
corresponding folder. Check the
packaging/windows/build_environment
file in the Mixxx codebase to see what version of the build environment
is currently used for builds.
The current recommended variant is "release". Release is the version used to produce Mixxx releases. It is compiled with LTCG enabled and requires at least 8 GB of memory (or equivalent free space on the disk with your paging file) to link Mixxx.
If you want to build a 32-bit version of Mixxx, choose an "x86" variant. For 64-bit, choose an "x64" variant.
Download and unzip one of these environments. The current recommended folder is inside MIXXX_REPO\buildenv (example: MIXXX_REPO\buildenv\2.3-j00019-x64-release-fastbuild-static-55e94982-minimal). We will refer to this folder as WINLIB_PATH later.
If you want to build the Mixxx dependencies from source instead of downloading pre-built ones:
- Clone the Mixxx buildserver repository.
Remember the folder to which the repository was saved. We will refer to that folder as WINLIB_PATH later. - In the buildserver repository, checkout the 2.?.x-windows branch, depending on which version of Mixxx you are building the dependencies for.
- Start a Windows command prompt (you do not need a Windows SDK command prompt). Open the Start Menu and type "cmd" into the search box and hit enter.
- Change into the WINLIB_PATH directory.
cd WINLIB_PATH_GOES_HERE
- Build the environment:
- 32-bit:
build_environment x86 Release
- 64-bit:
build_environment x64 Release
- 32-bit:
This step will take 2-3 hours depending on how many CPU cores you have. Go have lunch.
-
If you have not run MIXXX_REPO/tools/windows_buildenv.bat, it is recommended to do so. It will also generate a CMakeSettings.json that is used by Visual Studio so you don't need to generate it manually.
-
Open Visual Studio.
It will ask to open a project, select open Folder and select MIXXX_REPO. It will detect it as a CMake project. You can also do so from File-Open->CMake... and select the CMakeLists.txt file from MIXXX_REPO.
Select the correct build configuration on the toolbar. The CMakeSettings uses names like x64__fastbuild and so on. Most likely, the one you want is x64_portable. By default it will also generate the CMake cache using the configuration. You can also run it manually (and clean and regenerate it) by selecting the CMakeLists.txt file, and use the options Generate cache or CMake cache -> delete cache.
-
Go to Compile -> Compile All Menu option. The build should start. Depending on your processor, a full build can take from 5 to 20 minutes.
-
Open the application "x64 Native Tools command prompt for VS2019" from the Windows Start menu. There, go to MIXXX_REPO folder
-
Create a folder where we will setup cmake and build the sources. Usually we call this MIXXX_REPO\build
It is recommended that you actually create subfolders for different builds, as in:**MIXXX\_REPO**\build\x64__portable
**MIXXX\_REPO**\build\x86__portable
**MIXXX\_REPO**\build\x64__debug
Do the same for the install subdir ( MIXXX_REPO\install\x64_portable)
-
enter into this directory,
cd build\x64__portable
and type the following:cmake -G "Ninja" -DCMAKE_BUILD_TYPE=Release -DCMAKE_PREFIX_PATH="**WINLIB\_PATH**;**WINLIB\_PATH**\Qt-5.14.2" -DCMAKE_INSTALL_PREFIX=**MIXXX\_REPO**\install\x64_portable -DDEBUG_ASSERTIONS_FATAL=ON -DHSS1394=ON -DKEYFINDER=OFF -DLOCALECOMPARE=ON -DMAD=ON -DMEDIAFOUNDATION=ON -DSTATIC_DEPS=ON -DBATTERY=ON -DBROADCAST=ON -DBULK=ON -DHID=ON -DLILV=ON -DOPUS=ON -DQTKEYCHAIN=ON -DVINYLCONTROL=ON ..\..
You need to replace WINLIB_PATH and MIXXX_REPO for your paths, as well as adapting the install subdir if you build a different one. Also, the last part of the command "..\.." means MIXXX_REPO as seen from the cmake build dir (in our case MIXXX_REPO\build\x64__portable, so two subfolders)
Finally, set -DDEBUG_ASSERTIONS_FATAL=OFF instead of ON if you get assertion errors that close Mixxx. This is intended to detect errors quickly, but might be completely unexpected sometimes.
- Once it completes without errors, you can type
cmake --build .
so that it starts building. Depending on your processor, a full build can take from 5 to 20 minutes.
In order to do a clean build, you can do so with cmake --build . --clean-first
32bit versions are no longer being built, so they might stop working at some point. Anyway, these are some instructions on how you can do that.
-
Get the dependencies for 32bit: Either set the environment variable PLATFORM=x86 previous to execute the tools/windows_buildenv.bat script, or manually download the one for x86, or build it manually
-
Follow the instructions to build from commandline, but instead open a x86 Native tools command prompt for VS2019 (or x86_64 cross compile command prompt for VS2019). (Preferably the latter)
WARNING: DO NOT mix 32 and 64 bits builds. Use separate console windows and separate precompiled directories and cmake build directories
- There are no precompiled environments for debug, so this means that you have to
compile Mixxx dependencies from source as explained above. You will need to indicate this commandline to generate them in debug:build_environment xxx Debug
- Follow the instructions to build from commandline, but on the cmake instructions specify -DCMAKE_BUILD_TYPE=Debug instead of DCMAKE_BUILD_TYPE=Release.
WARNING: DO NOT mix release and debug builds. Use separate console windows and separate precompiled directories and cmake build directories
Mixxx is a free and open-source DJ software.
Manual
Hardware Compatibility
Reporting Bugs
Getting Involved
Contribution Guidelines
Coding Guidelines
Using Git
Developer Guide
Creating Skins
Contributing Mappings
Mixxx Controls
MIDI Scripting
Components JS
HID Scripting