Skip to content

Commit

Permalink
Use vcpkg for all platform presets
Browse files Browse the repository at this point in the history
  • Loading branch information
tophyr committed Jun 30, 2024
1 parent e68f270 commit e27f6fe
Show file tree
Hide file tree
Showing 6 changed files with 138 additions and 43 deletions.
9 changes: 6 additions & 3 deletions .github/workflows/build.yml
Original file line number Diff line number Diff line change
Expand Up @@ -66,22 +66,25 @@ jobs:
run: |
sudo apt update
sudo apt install -y --no-install-recommends \
ninja-build cmake g++ libgtest-dev libsdl2-dev zlib1g-dev libspdlog-dev
ninja-build cmake g++ libspdlog-dev
- name: Install Windows dependencies
if: ${{ matrix.os.runner == 'windows-latest' }}
run: choco install ninja

- uses: ilammy/msvc-dev-cmd@v1
if: ${{ matrix.os.runner == 'windows-latest' }}
with:
arch: win64

- uses: lukka/run-vcpkg@v11
with:
vcpkgJsonGlob: vcpkg.json

- name: Configure CMake
env:
CC: ${{ matrix.os.cc }}
CXX: ${{ matrix.os.cxx }}
VCPKG_ROOT: C:/vcpkg
run: cmake --preset ${{ matrix.os.preset }} -DBUILD_TESTING=ON -DENABLE_LOGGER=ON -DFORCE_PORTABLE_INSTALL=ON -DBUILD_EDITOR=ON

- name: Build ${{ matrix.build_type }}
Expand Down
7 changes: 0 additions & 7 deletions Brewfile
Original file line number Diff line number Diff line change
@@ -1,11 +1,4 @@
# Homebrew dependencies to build Descent3

# SDL
brew "sdl2"

brew "cmake"
brew "googletest"
brew "ninja"

# zlib
brew "zlib"
22 changes: 21 additions & 1 deletion CMakeLists.txt
Original file line number Diff line number Diff line change
@@ -1,5 +1,25 @@
cmake_minimum_required(VERSION 3.20) # For using CMAKE_<LANG>_BYTE_ORDER

if(NOT DEFINED USE_VCPKG OR USE_VCPKG)
message("NOT DEFINED USE_VCPKG OR USE_VCPKG")
if(DEFINED ENV{VCPKG_ROOT})
message("DEFINED ENV{VCPKG_ROOT}")
if (CMAKE_TOOLCHAIN_FILE)
cmake_path(ABSOLUTE_PATH CMAKE_TOOLCHAIN_FILE NORMALIZE OUTPUT_VARIABLE VCPKG_CHAINLOAD_TOOLCHAIN_FILE)
endif()

set(VCPKG_TOOLCHAIN_FILE "scripts/buildsystems/vcpkg.cmake")
cmake_path(ABSOLUTE_PATH VCPKG_TOOLCHAIN_FILE BASE_DIRECTORY $ENV{VCPKG_ROOT} NORMALIZE OUTPUT_VARIABLE CMAKE_TOOLCHAIN_FILE)

if(CMAKE_TOOLCHAIN_FILE STREQUAL VCPKG_CHAINLOAD_TOOLCHAIN_FILE)
# prevent endless recursion
unset(VCPKG_CHAINLOAD_TOOLCHAIN_FILE)
endif()
elseif(USE_VCPKG)
message(WARNING "USE_VCPKG=${USE_VCPKG} but ENV{VCPKG_ROOT} not set; will use system-provided libraries. Did you forget to set VCPKG_ROOT in your environment?")
endif()
endif()

# set default cmake build type to Debug (None Debug Release RelWithDebInfo MinSizeRel)
if(NOT CMAKE_BUILD_TYPE AND NOT DEFINED ENV{CMAKE_BUILD_TYPE})
set(CMAKE_BUILD_TYPE "Debug" CACHE STRING "default build type")
Expand All @@ -10,7 +30,7 @@ project(Descent3
VERSION 1.5.0
)

option(FORCE_COLORED_OUTPUT "Always produce ANSI-colored compiler warnings/errors (GCC/Clang only; esp. useful with ninja)." OFF)
option(FORCE_COLORED_OUTPUT "Always produce ANSI-colored compiler warnings/errors (GCC/Clang only; esp. useful with Ninja)." OFF)
option(FORCE_PORTABLE_INSTALL "Install all files into local directory defined by CMAKE_INSTALL_PREFIX" ON)
option(ENABLE_LOGGER "Enable logging to the terminal" OFF)
option(ENABLE_MEM_RTL "Enable Real-time library memory management functions (disable to verbose memory allocations)" ON)
Expand Down
3 changes: 1 addition & 2 deletions CMakePresets.json
Original file line number Diff line number Diff line change
Expand Up @@ -21,8 +21,7 @@
"architecture": {
"strategy": "external",
"value": "x64"
},
"toolchainFile": "$env{VCPKG_ROOT}/scripts/buildsystems/vcpkg.cmake"
}
},
{
"name": "mac",
Expand Down
131 changes: 102 additions & 29 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -92,17 +92,24 @@ The milestone needs testing on all platforms. Please report issues when found.
- D3 Open Source compiles level scripts in their own hogfiles. Make sure you copy and overwrite `d3-{platform}.hog`.

## Building
#### Dependencies
The build process uses [**CMake**](https://cmake.org/) and, by default, [**Ninja**](https://ninja-build.org/). You must install these; the project cannot locate them for you. The source code depends on [**SDL2**](https://github.com/libsdl-org/SDL) and [**zlib**](https://github.com/madler/zlib). You can supply these dependencies yourself via your system's library management tools, or the build system can locate the dependencies for you using [**vcpkg**](https://github.com/microsoft/vcpkg), a cross-platform dependency-management system developed by Microsoft. The official builds source their dependencies from **vcpkg**.

#### Installing and using **vcpkg**
* When building for Windows, **vcpkg** is already installed and configured when using the Developer Tools Command Prompt.
* For Android, Linux or Mac (or non-standard-Windows) configurations, you will need to install **vcpkg** locally by cloning https://github.com/microsoft/vcpkg and setting your `VCPKG_ROOT` env var to the repository location. With this environment variable set, the build will automatically locate its dependencies.

#### Building - Windows
1. Make sure that you have Git and Visual Studio 2022 with the “Desktop development with C++” workload and the “C++ MFC for latest v143 build tools (x86 & x64)” component. If you don’t already have those installed or you aren’t sure, then open an elevated Command Prompt and run:
1. Install the prerequisite build tools.

Make sure that you have Git and Visual Studio 2022 with the “Desktop development with C++” workload and the “C++ MFC for latest v143 build tools (x86 & x64)” component. If you don’t already have those installed or you aren’t sure, then open an elevated Command Prompt and run:
<!--
The following code block specifies the full path to the Visual Studio Installer because the Visual Studio Installer doesn’t add itself to the user’s Path. The installer is guaranteed to be in a specific location on 64-bit systems [1]. The installer will be in a different location on 32-bit systems [2], but Visual Studio 2022 doesn’t support 32-bit systems [3] so we can ignore that detail.
[1]: <https://learn.microsoft.com/en-us/visualstudio/install/use-command-line-parameters-to-install-visual-studio?view=vs-2022>
[2]: <https://github.com/microsoft/vswhere/wiki#installing>
[3]: <https://learn.microsoft.com/en-us/answers/questions/1689898/does-visual-studio-build-tools-2022-support-32-bit>
-->

```batch
winget install Git.Git Microsoft.VisualStudio.2022.Community
Expand All @@ -114,61 +121,127 @@ The milestone needs testing on all platforms. Please report issues when found.
--add Microsoft.VisualStudio.Component.VC.ATLMFC
```
2. Open a “x64 Native Tools Command Prompt” and run:
2. Clone the Descent3 source code.
Open a “**x64 Native Tools Command Prompt**” and run:
```batch
git clone https://github.com/DescentDevelopers/Descent3
```
3. Acquire the library dependencies.
The **Native Tools** prompts will already have **vcpkg** installed and configured for use, so no dependency management is needed.
4. Build Descent3.
Open a “**x64 Native Tools Command Prompt**” and run:
```batch
cd Descent3
cmake --preset win -D ENABLE_LOGGER=[ON|OFF] -D BUILD_EDITOR=[ON|OFF]
cmake --preset win
cmake --build --preset win --config [Debug|Release]
```
See "Build Options" below for more information on `Debug` vs `Release`.
Once CMake finishes, the built files will be put in `builds\win\Descent3\Debug` or `builds\win\Descent3\Release`.
#### Building - macOS
1. Make sure that [Xcode](https://developer.apple.com/xcode) is installed.
1. Install the prerequisite build tools.
2. Make sure that [Homebrew](https://brew.sh) is installed.
* Make sure that [Xcode](https://developer.apple.com/xcode) is installed.
* Make sure that [Homebrew](https://brew.sh) is installed.
3. Run these commands:
2. Clone the Descent3 source code.
Open a Terminal and run:
```sh
git clone https://github.com/DescentDevelopers/Descent3
```
3. Acquire the library dependencies.
* If you would like to use **vcpkg**:
```sh
git clone https://github.com/microsoft/vcpkg
cd vcpkg
export VCPKG_ROOT=$(pwd)
# IMPORTANT: You will need $VCPKG_ROOT defined for all build runs. It is a good idea to set this in your .bashrc or equivalent.
```
* If you would like to manage the code dependencies yourself:
```sh
brew install sdl2 zlib googletest
```
3. Build Descent3.
```sh
cd Descent3
brew bundle install
cmake --preset mac -D ENABLE_LOGGER=[ON|OFF]
cmake --preset mac
cmake --build --preset mac --config [Debug|Release]
```
See "Build Options" below for more information on `Debug` vs `Release`.
Once CMake finishes, the built files will be put in `builds/mac/Descent3/Debug` or `builds/mac/Descent3/Release`.
#### Building - Linux (Ubuntu)
Run these commands:
#### Building - Linux
1. Install the prerequisite build tools.
```sh
sudo apt update
sudo apt install -y --no-install-recommends git ninja-build cmake g++ libsdl2-dev zlib1g-dev
git clone https://github.com/DescentDevelopers/Descent3
cd Descent3
cmake --preset linux -D ENABLE_LOGGER=[ON|OFF]
cmake --build --preset linux --config [Debug|Release]
```
* Apt users (Debian, Ubuntu)
```sh
sudo apt update
sudo apt install -y --no-install-recommends git ninja-build cmake g++
```
* Dnf users (Red Hat, Fedora)
```sh
sudo dnf update --refresh
sudo dnf install -y git ninja-build cmake gcc-c++
```
Once CMake finishes, the built files will be put in `builds/linux/Descent3/Debug` or `builds/linux/Descent3/Release`.
2. Clone the Descent3 source code.
Open a Terminal and run:
```sh
git clone https://github.com/DescentDevelopers/Descent3
```
#### Building - Linux (Fedora)
Run these commands:
3. Acquire the library dependencies.
* If you would like to use **vcpkg**:
```sh
git clone https://github.com/microsoft/vcpkg
cd vcpkg
export VCPKG_ROOT=$(pwd)
# IMPORTANT: You will need $VCPKG_ROOT defined for all build runs. It is a good idea to set this in your .bashrc or equivalent.
```
* If you would like to manage the code dependencies yourself:
* Apt users
```sh
sudo apt install -y --no-install-recommends libsdl2-dev zlib1g-dev libgtest-dev
* Dnf users
```sh
sudo dnf install sdl2-devel zlib-devel gtest
```
3. Build Descent3.
```sh
sudo dnf update --refresh
sudo dnf install -y git ninja-build cmake gcc-c++ SDL2-devel zlib-devel
git clone https://github.com/DescentDevelopers/Descent3
cd Descent3
cmake --preset linux -D ENABLE_LOGGER=[ON|OFF]
cmake --build --preset linux --config [Debug|Release]
```
```sh
cd Descent3
cmake --preset linux
cmake --build --preset linux --config [Debug|Release]
```
See "Build Options" below for more information on `Debug` vs `Release`.
Once CMake finishes, the built files will be put in `builds/linux/Descent3/Debug` or `builds/linux/Descent3/Release`.
#### Build Options
* `Debug` vs `Release` TODO
* `BUILD_EDITOR` - Build internal editor. Default OFF.
* `BUILD_TESTING` - Enable testing. Requires GTest. Default OFF.
* `ENABLE_LOGGER` - Enable logging to the terminal. Default OFF.
* `ENABLE_MEM_RTL` - Enable Real-time library memory management functions (disable to verbose memory allocations). Default ON.
* `FORCE_COLORED_OUTPUT` - Always produce ANSI-colored compiler warnings/errors (GCC/Clang only; esp. useful with Ninja). Default OFF.
* `FORCE_PORTABLE_INSTALL` - Install all files into local directory defined by `CMAKE_INSTALL_PREFIX`. Default ON.
* `USE_VCPKG` - Explicitly control whether or not to use **vcpkg** for dependency resolution. ON requires `VCPKG_ROOT` environment variable set. Default behavior is determined by the existence of `VCPKG_ROOT` in the environment: If it exists, **vcpkg** is used.
## Contributing
Anyone can contribute! We have an active Discord presence at [Descent Developer Network](https://discord.gg/GNy5CUQ). If you are interested in maintaining the project on a regular basis, please contact Kevin Bentley.
9 changes: 8 additions & 1 deletion vcpkg.json
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,14 @@
"zlib",
{
"name": "sdl2",
"version>=": "2.30.3"
"version>=": "2.30.3",
"features": ["x11","wayland"],
"platform": "linux"
},
{
"name": "sdl2",
"version>=": "2.30.3",
"platform": "!linux"
}
],
"overrides": [
Expand Down

0 comments on commit e27f6fe

Please sign in to comment.