Skip to content

Build Instructions for Windows

jcm edited this page Nov 21, 2024 · 12 revisions

Note

This page applies to the in-development new build system. For current build instructions, see here.

ares on Windows can be built either via the default Windows shell, or within an MSYS2/MinGW environment.

Windows Command Prompt (MSVC/Clang-CL)

Prerequisites

  • Windows 10 or higher
  • CMake 3.28 or higher
  • Git for Windows
  • Visual Studio 17 2022

Ensure that the "Desktop Development with C++" package is included in your Visual Studio 2022 installation. Building ares with clang also requires that the "C++ Clang tools for Windows" package is installed.

Configuration

First, clone the ares repository:

git clone https://github.com/ares-emulator/ares
cd ares

A Visual Studio project can be setup by using the windows CMake preset:

cmake --preset windows

This preset will generate a Visual Studio project for ares using Clang-CL that will build all targets and package dependencies appropriately.

If you prefer to use the MSVC compiler, specify the windows-msvc preset:

cmake --preset windows-msvc

Visual Studio presets will generate single-architecture configuration with the host architecture will be created; if you would like to compile for a specific architecture, you may specify -A x64 or -A arm64 as appropriate. Multi-architecture configuration is not supported. 32-bit x86 builds are not currently supported (note 10/14: WIP, may work, just untested).

MSYS2/MinGW

Under MSYS2/MinGW, the same Visual Studio CMake presets above are also supported. Under MSYS2/MinGW, we may also however build with GNU Clang or GCC.

Prerequisites

  • MSYS2
  • An appropriate MSYS2 environment, such as CLANG64
  • A suitable MinGW toolchain, for example mingw-w64-llvm
  • Git (pacman -S git)
  • CMake 3.28 or higher (pacman -S cmake)

First, clone the ares repository:

git clone https://github.com/ares-emulator/ares
cd ares

Then, invoke CMake as normal with your chosen generator, e.g Ninja:

mkdir build && cd build
cmake .. -G "Ninja Multi-Config"

After configuration, build ares:

cmake --build . --config RelWithDebInfo

For further configuration options, see the Build Options page.