This guide contains steps required to allow compilation of Cataclysm-DDA on Windows using Visual Studio and vcpkg.
Steps from current guide were tested on Windows 10 (64 bit), Visual Studio 2019 (64 bit) and vcpkg, but should as well work with slight modifications for other versions of Windows and Visual Studio.
- Computer with modern Windows operating system installed (Windows 10, Windows 8.1 or Windows 7);
- NTFS partition with ~15 Gb free space (~10 Gb for Visual Studio, ~1 Gb for vcpkg installation, ~3 Gb for repository and ~1 Gb for build cache);
- Git for Windows (installer can be downloaded from Git homepage);
- Visual Studio 2019 (or 2015 Visual Studio Update 3 and above);
- Note: If you are using Visual Studio 2022, you must install the Visual Studio 2019 compilers to work around a vcpkg bug. In the Visual Studio Installer, select the 'Individual components' tab and search for / select the component that looks like 'MSVC v142 - VS 2019 C++ x64/x86 Build Tools'. See microsoft/vcpkg#22287.
- Latest version of vcpkg (see instructions on vcpkg homepage).
Note: Windows XP is unsupported!
-
Install
Visual Studio
(installer can be downloaded from Visual Studio homepage).- Select the "Desktop development with C++" and "Game development with C++" workloads.
-
Install
Git for Windows
(installer can be downloaded from Git homepage). -
Install and configure
vcpkg
. If you already havevcpkg
installed, you should update it to at least commitbd1ef2df46303989eeb048eb7aa9b816aa46365e
(the most recent tested good revision) and rerun.\bootstrap-vcpkg.bat
as described:
WARNING: It is important that, wherever you decide to clone this repo, the path does not include whitespace. That is, C:/dev/vcpkg
is acceptable, but C:/dev test/vcpkg
is not.
In a cmd.exe
shell:
REM cd to the appropriate folder first
git clone https://github.com/Microsoft/vcpkg.git
cd vcpkg
.\bootstrap-vcpkg.bat -disableMetrics
.\vcpkg integrate install
In a Git Bash shell, the commands are almost the same except the filesystem path separator is /
instead of \
.
# cd to the appropriate folder first
git clone https://github.com/Microsoft/vcpkg.git
cd vcpkg
./bootstrap-vcpkg.bat -disableMetrics
./vcpkg.exe integrate install
- Clone Cataclysm-DDA repository with following command line:
Note: This will download the entire CDDA repository; about three gigs of data. If you're just testing you should probably add --depth=1
.
git clone https://github.com/CleverRaven/Cataclysm-DDA.git
cd Cataclysm-DDA
-
Open the provided solution (
msvc-full-features\Cataclysm-vcpkg-static.sln
) inVisual Studio
.- Note: If you are using Visual Studio 2022, the first time you open the solution, it will prompt you to "Retarget Projects". Unless you know what you are doing, hit cancel on this dialog.
-
Open the
Build > Configuration Manager
menu and adjustActive solution configuration
andActive solution platform
to match your intended target.- The
Release
configuration andx64
platform together make a good default setting.Debug
is too slow and should be reserved for breakpoint debugging with code stepping. - This will configure Visual Studio to compile the release version, with support for Sound, Tiles, and Localization (note, however, that language files themselves are not automatically compiled; this will be done later).
- The
-
Start the build process by selecting either
Build > Build Solution
orBuild > Build > 1 Cataclysm-vcpkg-static
. The process may take a long period of time, so you'd better prepare a cup of coffee and some books in front of your computer :) The first build of each architecture will also download and install dependencies through vcpkg, which can take an especially long time. -
If you need localization support, execute the bash script
lang/compile_mo.sh
inside Git Bash GUI just like on a UNIX-like system. This will compile the language files that were not automatically compiled in step 2 above.
Even if you do not need languages other than English, you may still want to execute lang/compile_mo.sh
to compile the language files if you're planning to run the unit tests, since those rely on the language files existing.
-
Ensure that the Cataclysm project (
Cataclysm-vcpkg-static
) is the selected startup project.- Right click the project in the Solution Explorer pane, select
Set as Startup Project
- Right click the project in the Solution Explorer pane, select
-
Configure the working directory in the project settings to
$(ProjectDir)..
- Right click the project in the Solution Explorer pane, select
Properties
- Select Configuration to
All Configurations
and Platform toAll Platforms
- Under
Configuration Properties > Debugging
, changeWorking Directory
to$(ProjectDir)..
- Right click the project in the Solution Explorer pane, select
If you discover that after pressing the debug button in Visual Studio, Cataclysm just exits after launch with return code 1, that is because of the wrong working directory.
When debugging, it is not strictly necessary to use a Debug
build; Release
builds run significantly faster, can still be run in the debugger, and most of the time will have most of the information you need.
-
Ensure that the Cataclysm test project (
Cataclysm-test-vcpkg-static
) is the selected startup project. -
Configure the working directory in the project settings to
$(ProjectDir)..
-
Configure any extra command line arguments for the tests.
- Under
Configuration Properties > Debugging
, changeCommand Arguments
to the needed arguments. --wait-for-keypress exit
can be helpful by keeping the test window open at the end until you press Enter.
- Under
Additional command line arguments may be configured in the project's command line arguments setting, or if you are using a compatible unit test runner (e.g. Resharper) you can run or debug individual tests from the unit test sessions.
You can also start the test runner library manually from Windows console. Run it with --help
for an overview of the arguments.
There is a batch script in msvc-full-features
folder distribute.bat
. It will create a sub folder distribution
and copy all required files(eg. data/
, Cataclysm.exe
and dlls) into that folder. Then you can zip it and share the archive on the Internet.