Compiler SFML avec CMake
Introduction
Bon, d'accord, le titre de ce tutoriel n'est pas complètement exact. Vous n'allez pas compiler SFML avec CMake, car CMake n'est pas un compilateur. Mais alors CMake, c'est quoi ?
CMake est un meta-système de compilation. Au lieu de construire SFML, il va construire ce qui construit SFML : des solutions Visual Studio, des workspaces Code::Blocks, des makefiles Linux, des projets XCode, ... en fait il peut générer des makefiles et projets pour l'OS et le compilateur de votre choix. C'est un outil similaire à autoconf/automake ou premake -- pour ceux qui connaissent.
CMake est largement utilisé, par des projets connus tels que Blender, CLion, KDE, Ogre et bien d'autres. Vous pourrez en apprendre plus concernant CMake sur son site officiel ou sur la page Wikipedia.
Ainsi, comme vous l'aurez probablement compris, ce tutoriel est composé de deux sections : générer les projets/makefiles de compilation avec CMake, puis compiler SFML avec votre environnement préféré.
Installer les dependances
SFML dépend de quelques autres bibliothèques, ainsi avant de compiler vous devez avoir installé leurs fichiers de développement (en-têtes et bibliothèques).
Sous Windows et macOS, toutes les dépendances nécessaires sont fournies directement avec SFML, vous n'avez rien à télécharger/installer. La compilation fonctionnera directement.
Sous Linux c'est un peu différent, rien n'est fourni et SFML utilise votre propre installation des bibliothèques desquelles elle dépend. Voici une liste de ce que vous devez installer avant de compiler SFML :
- freetype
- jpeg
- x11
- xrandr
- xcb
- x11-xcb
- xcb-randr
- xcb-image
- opengl
- flac
- ogg
- vorbis
- vorbisenc
- vorbisfile
- openal
- pthread
Le nom exact des paquets dépend de chaque distribution. Et n'oubliez pas d'installer les versions de development de ces paquets.
Configurer la compilation de SFML
Cette étape consiste à créer les projets/makefiles qui pourront finalement compiler SFML. En gros, cela consiste à choisir quoi compiler, comment le compiler et où. Plus quelques autres options qui vous permettront de créer la compilation qui répondra parfaitement à vos besoins -- nous verrons cela en détail plus tard.
La première chose à choisir est l'endroit où les projets/makefiles et fichiers objets (les fichiers résultant de la compilation) seront créés. Vous pouvez les générer directement dans l'arborescence source (ie. la racine des répertoires SFML), mais cela va polluer votre répertoire SFML avec pas mal de déchets : une hiérarchie complète de fichiers de compilation, fichiers objets, etc. La solution la plus propre est de générer les projets/makefiles dans un répertoire complètement séparé, de manière à garder votre répertoire SFML intact. Utiliser des répertoires séparés vous permettra aussi d'avoir plusieurs compilations différentes en même temps (statique, dynamique, debug, release, ...).
Maintenant que vous avez choisi le répertoire de compilation, il y a encore une chose à faire avant de pouvoir lancer CMake. Lorsque CMake configure votre projet, il teste la disponibilité et la version du compilateur choisi. Ainsi, l'exécutable du compilateur doit être accessible quand CMake est lancé. Ce n'est pas un problème pour les utilisateurs Linux ou macOS, étant donné que les compilateurs sont installés dans des chemins standards et tout le temps accessibles, mais sous Windows il se pourrait que vous deviez ajouter le répertoire de votre compilateur à la variable d'environnement PATH, afin que CMake puisse le trouver automatiquement. Ceci est particulièrement important lorsque vous avez plusieurs compilateurs, ou plusieurs versions du même compilateur.
Sous Windows, si vous voulez utiliser GCC (MinGW), vous pouvez ajouter temporairement le répertoire MinGW\bin au PATH puis lancer CMake à partir de l'invite de commande :
> set PATH=%PATH%;votre_repertoire_mingw\bin
> cmake -G"MinGW Makefiles" ./build
Avec Visual C++, vous pouvez soit lancer CMake depuis l'"invite de commande de Visual Studio" disponible depuis le menu démarrer, ou bien appeler le fichier vcvars32.bat de votre installation de Visual Studio ; cela aura pour effet de configurer les variables d'environnement (notamment PATH) correctement.
> votre_repertoire_visual_studio\VC\bin\vcvars32.bat
> cmake -G"NMake Makefiles" ./build
Maintenant vous êtes prêts à faire tourner CMake. En fait, il y a trois façons différentes de l'invoquer :
- cmake-gui
Il s'agit de l'interface graphique, qui vous permet de tout configurer avec des boutons et des champs de saisie ; c'est probablement la meilleure solution pour les débutants et les personnes qui ne veulent pas s'embarasser de la ligne de commande ; c'est aussi très pratique pour voir et éditer les options disponibles. - cmake -i
Il s'agit de la ligne de commande interactive, elle vous invitera à remplir chaque option explicitement ; c'est un bon compromis pour démarrer avec la ligne de commande, étant donné que vous ne vous rappellerez certainement pas toutes les options qui sont disponibles, ni ne saurez lesquelles sont pertinentes. - cmake
C'est l'invocation directe, vous devez passer en un coup toutes les options avec leur valeur.
Je focaliserai ce tutoriel sur cmake-gui, étant donné que c'est très probablement ce qu'utiliseront les débutants. Je suppose que les personnes qui utilisent la ligne de commande peuvent en apprendre la syntaxe dans le manuel de CMake. A part les captures d'écran et les directives du genre "cliquez ici", les explications ci-dessous sont tout aussi valables pour la ligne de commande (les options sont les mêmes).
Voici à quoi ressemble cmake-gui :
Voici les toutes premières étapes à effectuer :
- Indiquez à CMake où se trouve le code source de SFML (ce doit être la racine de la hiérarchie SFML, là où se trouve le premier fichier CMakeLists.txt).
- Choisissez où vous voulez générer les projets/makefiles (si le répertoire n'existe pas, CMake le créera).
- Cliquez sur le bouton "Configure".
Si c'est la première fois que vous générez le projet (ou si vous avez effacé le cache de CMake), cmake-gui vous demandera de choisir le générateur. En d'autres termes, c'est là que vous sélectionnez votre compilateur/EDI.
Par exemple, pour générer une solution Visual Studio 10, vous devez choisir "Visual Studio 10". Pour générer des makefiles utilisables avec Visual
C++, sélectionnez "NMake Makefiles". Pour créer des makefiles utilisables avec MinGW (GCC), sélectionnez "MinGW Makefiles". Il est généralement
plus pratique de générer des makefiles plutôt que des projets pour EDI : vous pouvez compiler avec une simple commande, ou même rassembler plusieurs
compilations dans un simple script. Etant donné que vous ne ferez que compiler et non éditer les sources, les projets pour EDI sont généralement
inutiles.
Le processus d'installation (décrit plus loin dans ce document) peut ne pas fonctionner avec Xcode ; c'est pourquoi il est fortement recommendé d'utiliser le générateur de Makefile sur macOS.
Gardez toujours l'option "Use default native compilers", vous n'avez pas à vous préoccuper des trois autres.
Après avoir sélectionné le générateur, CMake va lancer tout un tas de tests pour vérifier diverses informations à propos de votre environnement de compilation : le chemin du compilateur, les en-têtes standards, les dépendances de SFML, etc. Si tout se passe bien, il devrait terminer avec le message "Configuring done". Si quelque chose s'est mal passé, lisez attentivement le(s) message(s) d'erreur. Peut-être que votre compilateur n'était pas accessible (voir ci-dessus), ou peut-être une dépendance était-elle manquante.
Après que CMake ai terminé la configuration, des options apparaissent dans la partie centrale de la fenêtre. CMake possède beaucoup d'options, mais
la plupart ont la bonne valeur par défaut. Beaucoup d'options ne sont même pas faites pour être éditées, elles sont simplement là pour vous montrer
ce que CMake a trouvé tout seul.
Voici la liste des quelques options vraiment importantes pour configurer votre compilation de SFML :
Variable | Description |
---|---|
CMAKE_BUILD_TYPE |
Cette option définit le type de compilation. Les valeurs disponibles sont "Debug" et "Release" (il existe d'autres types tels que "RelWithDebInfo" ou "MinSizeRel", mais celles-ci ne sont pas vraiment prises en compte par SFML). Notez que si vous générez un projet pour un EDI qui supporte les configurations multiples, comme par exemple Visual Studio, cette option est ignorée et vous aurez automatiquement toutes les configurations disponibles dans votre projet. |
CMAKE_INSTALL_PREFIX |
Cette option définit le chemin d'installation pour les fichiers compilés. Par défaut, il s'agit du chemin le plus naturel pour l'OS ciblé ("/usr/local" pour Linux et macOS, "C:\Program Files" pour Windows, etc.). Le fait d'installer les fichiers après les avoir compilé n'est pas obligatoire, vous pouvez utiliser les bibliothèques SFML directement à partir de là où elles sont compilées, mais il est tout de même préférable de les installer proprement afin de ne pas se trimballer tous les fichiers temporaires produits par la compilation. |
CMAKE_INSTALL_FRAMEWORK_PREFIX |
Cette option définit le chemin d'installation des frameworks. Par défaut, il s'agit de la bibliothèque
racine, i.e. le dossier /Library/Frameworks. Comme mentionné pour CMAKE_INSTALL_PREFIX, il n'est pas
obligatoire d'installer les fichiers après les avoir compilé, cependant il reste plus propre de le faire. Ce chemin est utilisé pour installer sndfile.framework sur votre système (une dépendance non fournie par Apple) ansi que SFML en tant que frameworks si l'option BUILD_FRAMEWORKS est activée. |
BUILD_SHARED_LIBS |
Cette option booléenne détermine si les bibliothèques SFML sont compilées en version dynamique (shared), ou statique. Cette option n'est pas compatible avec SFML_USE_STATIC_STD_LIBS, elles sont mutuellement exclusives. |
SFML_BUILD_FRAMEWORKS |
Cette option booléenne détermine si vous voulez compiler la SFML en tant que
frameworks bundle
ou en tant que
binaires dylib.
Produire des frameworks nécessite que l'option BUILD_SHARED_LIBS soit activée. Il est recommandé d'utiliser SFML en tant que frameworks quand vous distribuez votre application au public. Par contre, SFML ne peut pas être construite en tant que framework en type "Debug" ; à la place utilisez les dylibs. |
SFML_BUILD_EXAMPLES |
Cette option booléenne détermine si vous voulez compiler les exemples SFML ou non. |
SFML_BUILD_DOC |
Cette option booléenne détermine si vous voulez générer la documentation de SFML ou non. Notez que l'outil
doxygen doit être installé et accessible, sinon
le fait d'activer cette option produira une erreur. Sur macOS, vous pouvez installer l'exécutable Unix-classique dans /usr/bin ou n'importe quel dossier similaire, ou installer Doxygen.app dans n'importe quel dossier "Applications", par exemple ~/Applications. |
SFML_USE_STATIC_STD_LIBS |
Cette option booléenne choisit la version des bibliothèques C/C++ standard auxquelles SFML est liée. TRUE lie les bibliothèques standard statiquement, ce qui signifie que SFML est self-contained et ne dépend pas des DLLs spécifiques au compilateur. FALSE (la valeur par défaut) lie les bibliothèques standard dynamiquement, ce qui signifie que SFML dépend des DLLs du compilateur (msvcrxx.dll/msvcpxx.dll pour Visual C++, libgcc_s_xxx-1.dll/libstdc++-6.dll pour GCC). Soyez attentif à ce paramètre, s'il ne colle pas aux paramètres de vos projets utilisant SFML, vous pourriez faire face à des crashs dans certains cas. Cette option n'est pas compatible avec BUILD_SHARED_LIBS, elles sont mutuellement exclusives. |
CMAKE_OSX_ARCHITECTURES |
Ce paramètre définit pour quelles architectures SFML doit être compilée. La valeur recommandée est "x86_64" parce que la compilation en 32-bit n'est plus supportée. |
SFML_INSTALL_XCODE_TEMPLATES |
Cette option booléenne détermine si CMake va installer les templates pour Xcode sur votre système ou non. Vérifiez que /Library/Developer/Xcode/Templates/SFML existe et soit accessible à l'écriture. De plus amples informations sur ces templates sont données dans le tutoriel "Démarrer sur macOS". |
SFML_INSTALL_PKGCONFIG_FILES |
Cette option booléenne détermine si CMake va installer les fichiers pkg-config sur votre système ou non. pkg-config est un outil qui fournit une interface unifiée pour interroger les bibliothèques installées. |
Après avoir fait un tour dans les options, cliquez sur le bouton "Configure" une fois de plus : le fond des options devrait passer de rouge à blanc, et le bouton "Generate" devrait devenir accessible. Cliquez sur ce dernier pour enfin créer les makefiles/projets.
CMake crée un cache pour chaque projet. Ainsi, si vous décidez de revenir plus tard, vous retrouverez vos options telles que vous les aviez laissées et vous pourrez les modifier, puis reconfigurer et mettre à jour les makefiles/projets SFML.
C++11 et macOS
Si vous voulez utiliser les fonctionnalités de C++11 dans votre application, vous devez utiliser clang (le compilateur officiel d'Apple) avec libc++. De plus, vous devez compiler SFML avec ces outils pour éviter tout problème d'incompatilité entre bibliothèques standards et compilateurs.
Voici les paramètres à utiliser pour compiler SFML avec clang et libc++ :
- Choisissez "Specify native compilers" au lieu de "Use default native compilers" lorsque vous sélectionnez le générateur
CMAKE_CXX_COMPILER
configuré à /usr/bin/clang++ (voir capture d'écran)CMAKE_C_COMPILER
configuré à /usr/bin/clang (voir capture d'écran)CMAKE_CXX_FLAGS
etCMAKE_C_FLAGS
configurés à "-stdlib=libc++"
Compiler SFML
Commençons cette nouvelle section avec une bonne nouvelle : vous n'aurez plus à exécuter l'étape de configuration décrite ci-dessus, même si vous mettez à jour les sources de SFML. CMake est futé, il ajoute aux makefiles/projets générés une étape personnalisée, qui regénère automatiquement tous les fichiers nécessaires à chaque fois que quelque chose a changé.
Vous êtes maintenant prêts à compiler SFML. Bien entendu, la manière de faire dépend des makefiles/projets que vous avez choisi de générer. Si vous avez créé un projet/solution/workspace, ouvrez-le avec votre EDI et compilez le comme n'importe quel autre projet. Je n'entrerai pas dans le détail ici, il existe bien trop d'EDIs différents et je suppose que vous connaissez le vôtre suffisamment pour exécuter cette simple tâche.
Si vous avez généré un makefile, ouvrez une invite de commande et exécutez la commande "make" correspondant à votre environnement. Par exemple,
lancez "nmake" si vous avez généré un makefile NMake (Visual C++), "mingw32-make" si vous avez généré un makefile MinGW (GCC), ou simplement
"make" si vous avez généré un makefile Linux.
Note : sous Windows, le programme de "make" (nmake ou mingw32-make) peut ne pas être accessible. Si c'est le cas, n'oubliez pas d'ajouter son
chemin à la variable d'environnement PATH ; voir les explications au début de la section "Configurer la compilation de SFML" pour plus de détails.
Par défaut, tout sera compilé (les bibliothèques SFML, ainsi que les exemples si vous avez activé l'option SFML_BUILD_EXAMPLES). Si vous voulez compiler
uniquement une seule bibliothèque SFML, ou un exemple particulier, vous pouvez choisir une cible différente. Vous pouvez aussi choisir de nettoyer
ou d'installer les fichiers compilés, avec les cibles adéquates.
Voici toutes les cibles disponibles, selon les options de configuration que vous avez choisies :
Cible | Description |
---|---|
all |
C'est la cible par défaut, elle est utilisée si aucune cible n'est explicitement spécifiée. Elle construit toutes les cibles qui produisent des fichiers binaires (les bibliothèques SFML et les exemples). |
sfml-system |
Construit la bibliothèque SFML correspondante. La cible "sfml-main" n'est disponible que sous Windows. |
cocoa |
Construit l'exemple SFML correspondant. Ces cibles ne sont disponibles que si l'option SFML_BUILD_EXAMPLES a été activée. Notez que certains
exemples ne sont définis que pour un OS particulier ("cocoa" n'est disponible que sous macOS, "win32" sous Windows, "X11" sous Linux, etc.).
|
doc |
Génère la documentation de l'API. Cette cible n'est disponible que si l'option SFML_BUILD_DOC a été activée.
|
clean |
Supprime tous les fichiers objets produits par la compilation précédente. Vous n'avez généralement pas besoin d'invoquer cette cible, excepté lorsque vous souhaitez recompiler SFML entièrement (certaines mises à jour du code interagissent mal avec les fichiers objets déjà compilés, et tout supprimer est alors la seule solution). |
install |
Installe SFML dans le chemin défini par les options CMAKE_INSTALL_PREFIX et CMAKE_INSTALL_FRAMEWORK_PREFIX . Cela va copier
les bibliothèques et en-têtes SFML, ainsi que les exemples et la documentation si les options SFML_BUILD_EXAMPLES et SFML_BUILD_DOC
ont été activées. Après installation, vous obtenez une distribution propre de SFML, tout comme si vous aviez téléchargé un SDK officiel, ou installé SFML
depuis les dépôts système.
|
Si vous utilisez un EDI, une cible est simplement un projet. Pour construire une cible, sélectionnez le projet correspondant et compilez le
(même les cibles "clean" et "install" doivent être compilées afin d'être exécutées -- ne soyez pas surpris par le fait qu'il n'y a en fait aucun
code source à compiler).
Si vous utilisez un makefile, passez le nom de la cible à la commande de "make" afin de construire cette cible. Exemples :
"nmake doc
", "mingw32-make install
", "make sfml-network
".
Maintenant vous devriez avoir compilé SFML avec succès. Félicitations !