SDL Wiki
[ front page | index | search | recent changes | git repo | offline html ]

Introduction to SDL_net with CMake

The easiest way to use SDL_net is to include it along with SDL as subprojects in your project.

We'll start by creating a simple project to build and run hello.c

Create the file CMakeLists.txt

cmake_minimum_required(VERSION 3.16)
project(hello)

# set the output directory for built objects.
# This makes sure that the dynamic library goes into the build directory automatically.
set(CMAKE_RUNTIME_OUTPUT_DIRECTORY "${CMAKE_BINARY_DIR}/$<CONFIGURATION>")
set(CMAKE_LIBRARY_OUTPUT_DIRECTORY "${CMAKE_BINARY_DIR}/$<CONFIGURATION>")

# This assumes the SDL source is available in vendored/SDL
add_subdirectory(vendored/SDL EXCLUDE_FROM_ALL)

# This assumes the SDL_net source is available in vendored/SDL_net
add_subdirectory(vendored/SDL_net EXCLUDE_FROM_ALL)

# Create your game executable target as usual
add_executable(hello WIN32 hello.c)

# Link to the actual SDL3 library.
target_link_libraries(hello PRIVATE SDL3_net::SDL3_net SDL3::SDL3)

Build:

cmake -S . -B build
cmake --build build

Run:

cd build/Debug
./hello
cd build
./hello

[ edit | delete | history | feedback | raw ]

All wiki content is licensed under Creative Commons Attribution 4.0 International (CC BY 4.0).
Wiki powered by ghwikipp.