Une solution complète aux problèmes de configuration de la compilation
Vous' J'ai rencontré quelques défis dans la gestion des options du compilateur dans votre projet multiplateforme CMake. Plongeons dans une approche modernisée qui répond à vos préoccupations et fournit une solution robuste.
1. Désencombrez votre fichier CMake avec des fonctionnalités avancées
Au lieu de définir manuellement CMAKE_CXX_FLAGS, envisagez d'utiliser les techniques suivantes :
Remplacez la spécification standard C explicite par :
<code class="cmake">string(APPEND _opts "$<IF:$<CXX_COMPILER_ID:MSVC>, "/W4;$<$<CONFIG:RELEASE>:/O2>", "-Wall;-Wextra;-Werror; $<$<CONFIG:RELEASE>:-O3>" "$<$<CXX_COMPILER_ID:Clang>:-stdlib=libc++>" ">" ) add_compile_options("${_opts}")</code>
Cela spécifie les dépendances exactes des fonctionnalités C de votre projet, en gérant la compatibilité du compilateur et en fournissant des messages d'erreur pour les fonctionnalités non prises en charge.
3. Atteignez plusieurs cibles dans un seul répertoire à l'aide de wrappers<code class="cmake">target_compile_features(HelloWorld PUBLIC cxx_lambda_init_captures)</code>
Considérations supplémentaires :
Les expressions génératrices nécessitent la version CMake >= 3.8.
Les expressions génératrices doivent être écrites sur une seule ligne. Pensez à utiliser string(APPEND) pour améliorer la lisibilité.La prise en charge de CMake par Visual Studio 2017 vous permet d'intégrer plusieurs compilateurs et configurations dans un seul espace de travail.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!