SFML mainline mirror
Go to file
James Cowgill ad70442246 Do not cache atom name if XInternAtom fails
If `XInternAtom` is called with `onlyIfExists` set, then it can
legitimately return `None`. We should not cache this value because it
might change in the future.

This bug can sometimes be triggered because we use
`getAtom("UTF8_STRING", true)` and `getAtom("UTF8_STRING")`. If the
first call caches `None` because the atom didn't exist, then the
second call could return `None` instead of creating a new atom like it
should.
2024-12-05 08:48:44 +01:00
.github Ensure a C compiler is found during configuration 2024-12-05 08:46:09 +01:00
cmake Build dependency libraries instead of bundling pre-built binaries. 2024-12-04 23:52:24 +01:00
doc Use standard CMake variables for Doxygen paths 2024-09-12 12:21:09 -06:00
examples Build dependency libraries instead of bundling pre-built binaries. 2024-12-04 23:52:24 +01:00
extlibs Build dependency libraries instead of bundling pre-built binaries. 2024-12-04 23:52:24 +01:00
include/SFML Add comment regarding input monitoring access on macOS 2024-12-05 08:38:16 +01:00
src/SFML Do not cache atom name if XInternAtom fails 2024-12-05 08:48:44 +01:00
test Build dependency libraries instead of bundling pre-built binaries. 2024-12-04 23:52:24 +01:00
tools Build dependency libraries instead of bundling pre-built binaries. 2024-12-04 23:52:24 +01:00
.clang-format Replaced OpenAL with miniaudio. 2024-04-25 10:24:11 +02:00
.clang-tidy Build dependency libraries instead of bundling pre-built binaries. 2024-12-04 23:52:24 +01:00
.editorconfig Added an .editorconfig file 2015-02-06 11:07:39 +01:00
.gitattributes Fix file extension typo in .gitattributes 2024-01-15 16:47:09 -07:00
.gitignore gitignore vs folder 2024-08-20 15:50:14 +01:00
changelog.md Merge branch '2.6.x' into feature/backmerge 2024-11-19 13:02:44 -07:00
CMakeLists.txt Ensure a C compiler is found during configuration 2024-12-05 08:46:09 +01:00
CMakePresets.json Enable standard library assertions in CI 2024-06-23 08:37:06 +02:00
CONTRIBUTING.md Turned the header image in readme.md into a link. 2018-02-10 17:12:54 +01:00
license.md Update copyright year 2024-01-26 12:00:22 -07:00
migration.md Update migration guide 2024-11-25 15:02:11 -07:00
readme.md Updated readme to point to SFML 2.6.1 2024-04-30 00:46:27 +00:00

SFML logo

SFML — Simple and Fast Multimedia Library

SFML is a simple, fast, cross-platform and object-oriented multimedia API. It provides access to windowing, graphics, audio and network. It is written in C++, and has bindings for various languages such as C, .Net, Ruby, Python.

State of Development

Development is focused on the next major version in the master branch. No more features are planned for the 2.x release series.

  • The master branch contains work in progress for the next major version SFML 3. As such it's considered unstable, but any testing and feedback is highly appreciated.
  • The 2.6.1 tag is the latest official SFML release and will be the last minor release in the 2.x series.

CMake Template

The easiest way to get started with SFML is our CMake-based project template. This template will automatically download and build SFML alongside your own application. Read the README for full instructions on how to use it.

Download

  • You can get the latest official release on SFML's website.
  • You can also get the source code of the current development version from the Git repository.
  • Alternatively, you can get the latest snapshot / artifact builds from the artifacts storage.

Install

Follow the instructions of the tutorials, there is one for each platform/compiler that SFML supports.

Learn

There are several places to learn SFML:

Community

Here are some useful community links:

Contribute

SFML is an open-source project, and it needs your help to go on growing and improving. If you want to get involved and suggest some additional features, file a bug report or submit a patch, please have a look at the contribution guidelines.

Authors

License

The SFML libraries and source code are distributed under the zlib/libpng license. See license.md. External libraries used by SFML are distributed under their own licenses.

In short, SFML is free for any use (commercial or personal, proprietary or open-source). You can use SFML in your project without any restriction. You can even omit to mention that you use SFML -- although it would be appreciated.

External libraries used by SFML