This repository template should allow for a fast and hassle-free kick start of your next SFML project using CMake. Thanks to GitHub's nature of templates, you can fork this repository without inheriting its Git history.
The template starts out very basic, but might receive additional features over time:
- Basic CMake script to build your project and link SFML on any operating system
- Basic GitHub Actions script for all major platforms
-
Follow the above instructions about how to use GitHub's project template feature to create your own project.
-
Open CMakeLists.txt. Rename the project and the executable to whatever name you want. The project and executable names don't have to match.
-
If you want to add or remove any .cpp files, change the source files listed in the
add_executable
call in CMakeLists.txt to match the source files your project requires. If you plan on keeping the default main.cpp file then no changes are required. -
Configure and build your project. Most popular IDEs support CMake projects with very little effort on your part.
Using CMake from the command line is straightforward as well.
For a single-configuration generator (typically the case on Linux and macOS):
cmake -S . -B build -DCMAKE_BUILD_TYPE=Release cmake --build build
For a multi-configuration generator (typically the case on Windows):
cmake -S . -B build cmake --build build --config Release
-
Enjoy!
SFML is found via CMake's FetchContent module. FetchContent automatically downloads SFML from GitHub and builds it alongside your own code. Beyond the convenience of not having to install SFML yourself, this ensures ABI compatability and simplifies things like specifying static versus shared libraries.
Modifying what version of SFML you want is as easy as changing the GIT_TAG
argument.
Currently it uses the latest in-development version of SFML 2 via the 2.6.x
tag.
If you're feeling adventurous and want to give SFML 3 a try, use the master
tag.
Beware, this requires changing your code to suit the modified API!
The nice folks in the SFML community can help you with that transition and the bugs you may encounter along the way.
Modify CMake options by adding them as configuration parameters (with a -D
flag) or by modifying the contents of CMakeCache.txt and rebuilding.
By default SFML builds shared libraries and this default is inherited by your project.
CMake's BUILD_SHARED_LIBS
option lets you pick static or shared libraries for the entire project.
See the variety of CMAKE_<LANG>_COMPILER
options.
In particular you'll want to modify CMAKE_CXX_COMPILER
to point to the C++ compiler you wish to use.
CMake abstracts away specific optimizer flags through the CMAKE_BUILD_TYPE
option.
By default this project recommends Release
builds which enable optimizations.
Other build types include Debug
builds which enable debug symbols but disable optimizations.
If you're using a multi-configuration generator (as is often the case on Windows), you can modify the CMAKE_CONFIGURATION_TYPES
option.
While CMake will attempt to pick a suitable default generator, some systems offer a number of generators to choose from.
Ubuntu, for example, offers Makefiles and Ninja as two potential options.
For a list of generators, click here.
To modify the generator you're using you must reconfigure your project providing a -G
flag with a value corresponding to the generator you want.
You can't simply modify an entry in the CMakeCache.txt file unlike the above options.
Then you may rebuild your project with this new generator.
Here, I use another C++11 feature: the variadic template. As you know, sf::Transformable has two versions of the setPosition() method. The first one takes two float numbers, and the second takes sf::Vector2f as the parameter. Because I don't want to build the two versions, I use a new possibility of C++. I simply forward the arguments to sf::Transformable::setPosition() without knowing them. By using this, we can use both of the sf::Transformable:: setPosition() functions.
Since we don't want to fix the type of parameter (constant, left-reference, or right- reference), we use another feature of C++11: the right value reference or, in this context, the forwarding/universal reference. This allows us to catch any kind of type by simply adding &&. The final signature of the function now is as follows: template<typename ... Args> void setPosition(Args&& ... args);
In this chapter, we covered the general game architecture, the input management, and the resources. You also learned about the RAII idiom and some C++11 features such as lambda, variadic templates, smart pointers, move syntax, and perfect forwarding.