-
-
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
If you want to compile Mixxx, you'll need to download the source code. Source archives for releases are on downloads.mixxx.org, but if you want to contribute to Mixxx, we recommend forking the project. Check out Set up Git to get started.
To build Mixxx, you need built copies of its dependencies. Mixxx uses the VCPKG pacakge manager to build the dependencies (also called build environment or buildenv). this is maintained in the repo https://github.com/mixxxdj/vcpkg 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\mixxx-deps-2.4-x64-windows-92b7b90.zip and extract the ZIP archive to a directory with the same name.
You find the ZIP archives at: https://downloads.mixxx.org/dependencies/2.4/Windows/
The folder 2.?.x-windows
contains build environments for the 2.?
release of Mixxx. If you are working on the Main 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.
Download and unzip one of these environments. The current recommended folder is inside MIXXX_REPO\buildenv (example: MIXXX_REPO\buildenv\mixxx-deps-2.4-x64-windows-92b7b90).
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. - Github actions will build it automatically according the setup (including the list of dependencies) in https://github.com/mixxxdj/vcpkg/blob/2.4/.github/workflows/build.yml
- When Github Action finishes the build, you can download the buildenv as ZIP file from the artifacts.
The build will take some hours.
-
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\x64__native
**MIXXX\_REPO**\build\x64__off
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="**MIXXX\_REPO**\buildenv;**MIXXX\_REPO**\buildenv\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 MIXXX_REPO\buildenv 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