Building Cahute for Microsoft Windows¶
Warning
In order to install Cahute on Windows, it is recommended to use one of the methods in Installing Cahute on Microsoft Windows. However, if you wish to build Cahute manually, this guide is for you.
The following building methods are available.
Note
Since you will not be using a packaged version of Cahute, the project won’t be automatically updated when updating the rest of the system, which means you will need to do it manually, especially if a security update is made.
You can subscribe to releases by creating a Gitlab.com account, and following the steps in Get notified when a release is created. You can check your notification settings at any time in Notifications.
Building Cahute for Windows Vista and above, using Visual Studio¶
Warning
Both Windows XP and above as a target and this build method are not officially supported yet.
See Microsoft Windows for more information.
It is possible to build Cahute for Windows Vista and above, using Microsoft’s Visual Studio.
Setting up the project and configuration¶
If you have not set up the project, you must follow the instructions in Cloning the Cahute repository in Visual Studio.
Once this is done, you need to go to the project’s CMake configurations, by going in “Project”, then “CMake settings for cahute”:
Look for “x64-Windows” in the configuration list. If you do not have such a configuration yet, click on the “+” icon:
This will open a list of configurations to add. Look for “x64-Release”, then click on “Select” at the bottom of the window:
Once this is selected, the new configuration should appear in your list. Select it, then click on the configuration type to update its value to “Release”:
Once this is selected, you can save by clicking on the floppy on the top left of the IDE, or using the Ctrl+S shortcut.
Warning
You may have the following error when configuring the project using CMake:
Could NOT find PkgConfig (missing: PKG_CONFIG_EXECUTABLE)
This is likely, in fact, an error with the vcpkg integration with Visual Studio, as by default, packages are not installed and accessed. In order to do this, as described in Installing and using packages (vcpkg), you can either:
Integrate
vcpkg
for all projects with Visual Studio, by runningvcpkg integrate install
;Only enable
vcpkg
by setting the CMake toolchain option to your vcpkg install’svcpkg.cmake
:
Building the project¶
From here, you can select the target you want to build next to the green arrow
on the top, and the architecture you’re targetting. By leaving the default
(x64-Debug
) and clicking on p7.exe
, we obtain the following:
Since Cahute defines mostly command-line utilities, it may be more interesting to have access to a command-line interface. In order to this, in the context menu, select “Tools”, “Command line”, then “Developer Powershell”:
A console should open at the bottom of the IDE. In this console, use cd
to go to the build directory (by default, .\out\build\<target>
), and
run the command-line utilities from here with the options you want to test.
Building Cahute for Windows XP, using Visual Studio¶
Warning
Both Windows XP and above as a target and this build method are not officially supported yet.
See Microsoft Windows for more information.
Warning
This build method is not functional yet due to a bug with Visual Studio and the Windows SDK; see #68 for more details.
For now, you can build for Windows XP using the Building Cahute for Windows XP and above, using Visual Studio and MinGW-w64 guide.
It is possible to build Cahute for Windows XP, using Microsoft’s Visual Studio.
Installing the MSVC v141_xp toolset for Visual Studio¶
By default, Visual Studio Installer selects MSVC v143 or later, which does not support Windows XP. In order to support Windows XP, you will need to open Visual Studio Installer, modify your existing installation, go to “Individual components”, then select everything pertaining to MSVC v141:
You can then select “Modify” at the bottom right of the window in order to download and configure MSVC v141.
Installing the Windows 8.1 SDK¶
By default, Visual Studio with the MSVC v141_xp toolset does not select the correct SDK version, so Cahute makes an effort to find a compatible SDK it can use for some features. For XP compatibility, you need to download and install the Windows 8.1 SDK in Windows SDK and emulator archive:
Setting up the project and configuration¶
If you have not set up the project, you must follow the instructions in Cloning the Cahute repository in Visual Studio.
Once this is done, you need to go to the project’s CMake configurations, by going in “Project”, then “CMake settings for cahute”:
Look for “x64-Windows” in the configuration list. If you do not have such a configuration yet, click on the “+” icon:
This will open a list of configurations to add. Look for “x64-Release”, then click on “Select” at the bottom of the window:
Once this is selected, the new configuration should appear in your list. Select it, then click on the configuration type to update its value to “Release”:
Scroll down until you see “CMake command arguments”, and add -T v141_xp
in the matching dialog box:
Scroll down more until you reach the “Display advanced parameters”, on which you must click:
You can now scroll down more to “CMake generator”, which you must set to
Visual Studio 17 2022
:
Once this is selected, you can save by clicking on the floppy on the top left of the IDE, or using the Ctrl+S shortcut.
Building the project¶
From here, you can select the target you want to build next to the green arrow
on the top, and the architecture you’re targetting. By leaving the default
(x64-Debug
) and clicking on p7.exe
, we obtain the following:
Since Cahute defines mostly command-line utilities, it may be more interesting to have access to a command-line interface. In order to this, in the context menu, select “Tools”, “Command line”, then “Developer Powershell”:
A console should open at the bottom of the IDE. In this console, use cd
to go to the build directory (by default, .\out\build\<target>
), and
run the command-line utilities from here with the options you want to test.
Building Cahute for Windows XP and above, using Visual Studio and MinGW-w64¶
Warning
Both Windows XP and above as a target and this build method are not officially supported yet.
See Microsoft Windows for more information.
It is possible to build Cahute for Windows XP, using Microsoft’s Visual Studio and MinGW-w64.
Installing the required components¶
You need to install MinGW-w64 first. Pre-built binaries are available;
for this, go to MinGW-w64 Downloads to the WinLibs.com
section,
click on the link present in the section, then go to the Download
,
Release versions
, MSVCRT runtime
, and select the latest archive for
Win64:
Warning
You should only trust WinLibs.com
as long as they are referenced on
the MinGW-w64 website, as this website may be compromised at some point
(possibly as you read this!).
Once you’ve downloaded the archive, you can open it, and move the mingw64
directory it contains to any directory you like; for this guide, we will move
the directory to C:\
.
Setting up the project and configuration¶
If you have not set up the project, you must follow the instructions in Cloning the Cahute repository in Visual Studio.
Once this is done, you need to go to the project’s CMake configurations, by going in “Project”, then “CMake settings for cahute”:
Look for “Mingw64-Release” in the configuration list. If you do not have such a configuration yet, click on the “+” icon:
This will open a list of configurations to add. Look for “Mingw64-Release”, then click on “Select” at the bottom of the window:
Once this is selected, the new configuration should appear in your list. Select it, then click on the configuration type to update its value to “Release”:
Now, click on “Modify JSON” on the top right corner of the CMake parameters.
Look for the configuration with the “Mingw64-Release” name, then edit the
value for MINGW64_ROOT
to the path where you put MinGW-w64, in this
example C:/mingw64
.
Once this is done, you can save by clicking on the floppy on the top left of the IDE, or using the Ctrl+S shortcut.
Building the project¶
From here, you can select the configuration you want on the left of the green
arrow, then pick the target you want to build on the right of the green arrow
on the top. By selecting Mingw64-Release
and clicking on p7.exe
,
we obtain the following:
Since Cahute defines mostly command-line utilities, it may be more interesting to have access to a command-line interface. In order to this, in the context menu, select “Tools”, “Command line”, then “Developer Powershell”:
A console should open at the bottom of the IDE. In this console, use cd
to go to the build directory (by default, .\out\build\<target>
), and
run the command-line utilities from here with the options you want to test.
Building Cahute for Windows XP and above, using MinGW-w64 on Archlinux¶
Warning
Both Windows XP and above as a target and this build method are not officially supported yet.
See Microsoft Windows for more information.
Building Cahute for Windows XP and above from Archlinux using MinGW-w64 is possible, as described in Cross Compiling With CMake.
Downloading the Cahute source¶
In order to get the current released version of the Cahute source, you have the following options:
You can download the latest source package:
curl -o cahute-0.6.tar.gz https://ftp.cahuteproject.org/releases/cahute-0.6.tar.gz tar xvf cahute-0.6.tar.gz
You can clone the repository and checkout the tag corresponding to the release:
git clone https://gitlab.com/cahuteproject/cahute.git cahute-0.6 (cd cahute-0.6 && git checkout -f 0.6)
The project is present in the “cahute-0.6” directory.
Warning
If you are building the project in the context of the Creating a merge request guide, these commands need to be replaced by the following:
git clone <your-repo-url>
Where the repository’s URL can be obtained through the Code
button
on the Gitlab.com interface:
Installing the dependencies¶
You need to first install the required dependencies from the AUR, by using your favourite AUR helper, e.g. with paru:
paru -S cmake python python-toml mingw-w64 \
mingw-w64-cmake mingw-w64-libusb mingw-w64-sdl2
Building the project¶
In the parent directory to the source, you can now create the build
directory aside it, by running either one of the following command depending
on the architecture you’re targeting:
i686-w64-mingw32-cmake -B build -S cahute-0.6 x86_64-w64-mingw32-cmake -B build -S cahute-0.6
You can now build the project using the following command:
cmake --build build
Before testing with either Wine or a Windows host, it is recommended to copy the required shared libraries to the build directory, by running either one of the following command depending on the architecture you’re targetting:
cp /usr/i686-w64-mingw32/bin/{libssp-0,SDL2,libusb-1.0}.dll .
cp /usr/x86_64-w64-mingw32/bin/{libssp-0,SDL2,libusb-1.0}.dll .
Warning
In order for Cahute to be usable on Windows XP, you need to use a previous release of libusb as system requirements have been upgraded.
libusb 1.0.23 has been proven to work in such cases. The DLLs can be
found in the libusb-1.0.23.7z
archive, more specifically in the
MinGW32/dll
and MinGW64/dll
directories.
Note
For reference, this build method is used in the
MinGW build image for Cahute, which is exploited in the project’s
continuous integration pipelines as described in .gitlab-ci.yml
.