Prise en charge limitée de CMake pour plusieurs compilateurs
CMake utilise une politique stricte d'utilisation d'un seul compilateur universel pour tous les fichiers source C (CMAKE_CXX_COMPILER). Cette limitation inhérente pose des défis pour le mélange d'hôtes et la compilation croisée au sein du même projet.
Impossible de remplacer par cible
Actuellement, CMake ne dispose pas de l'infrastructure nécessaire pour remplacer CMAKE_CXX_COMPILER. réglage par cible. Cette restriction complique la gestion simultanée de compilateurs avec des architectures différentes.
Solutions :
1. Invocations CMake multiples :
Reconnaissant les limites de CMake, la solution la plus simple consiste à exécuter CMake plusieurs fois, chacune avec un compilateur différent attribué. Cette approche est pratique même pour des scénarios tels que la compilation de binaires 32 bits et 64 bits à partir de la même chaîne d'outils de compilateur.
2. Commandes personnalisées (non recommandées) :
Une méthode alternative, bien que moins élégante, consiste à recourir à des commandes personnalisées. Cette solution de contournement implique la création de scripts shell glorifiés qui contournent les mécanismes de gestion du compilateur intégrés de CMake. Cependant, cette approche s'écarte de l'objectif de CMake de maintenir la modularité et la portabilité.
3. Fichiers CMakeLists.txt séparés :
La solution la plus recommandée consiste à créer des fichiers CMakeLists.txt séparés pour différentes architectures ou compilateurs. Malgré l'inconvénient de plusieurs étapes de construction, cette approche garantit une séparation claire et facilite la compilation indépendante de chaque composant. Le maintien du code commun dans des fichiers include() séparés améliore la réutilisation du code et réduit la redondance.
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!