2017-07-22 3 views
0

Ich verwende ein benutzerdefiniertes Makro, um ein Compiler-Flag zur Kompilierung in CMAKE zu überprüfen und hinzuzufügen. Der Code, den ich dafür verwende ist:Compiler-Flag zweimal in CMake überprüft CHECK_CXX_COMPILER_FLAG

MACRO(CheckAndAddFlag flag) 
    # We cannot check for -Wno-foo as this won't throw a warning so we must check for the -Wfoo option directly 
    # http://stackoverflow.com/questions/38785168/cc1plus-unrecognized-command-line-option-warning-on-any-other-warning 
    STRING(REGEX REPLACE "^-Wno-" "-W" checkedFlag ${flag}) 
    SET(VarName ${checkedFlag}) 
    STRING(REPLACE "+" "X" VarName ${VarName}) 
    STRING(REPLACE "-" "_" VarName ${VarName}) 
    # Avoid double checks. A compiler will not magically support a flag it did not before 
    MESSAGE(STATUS "Checking CXX_FLAG_${VarName}_SUPPORTED. Checked? ${VarName}_CHECKED= ${${VarName}_CHECKED} end") 
    if(NOT ${VarName}_CHECKED) 
     CHECK_CXX_COMPILER_FLAG(${checkedFlag} CXX_FLAG_${VarName}_SUPPORTED) 
     CHECK_C_COMPILER_FLAG(${checkedFlag} C_FLAG_${VarName}_SUPPORTED) 
     set(${VarName}_CHECKED YES CACHE INTERNAL "") 
     MESSAGE(STATUS "Checked CXX_FLAG_${VarName}_SUPPORTED. Checked? ${VarName}_CHECKED= ${${VarName}_CHECKED} end") 
    endif() 
    IF (CXX_FLAG_${VarName}_SUPPORTED) 
     set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${flag}") 
    ENDIF() 
    IF (C_FLAG_${VarName}_SUPPORTED) 
     set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${flag}") 
    ENDIF() 
    unset(VarName) 
    unset(checkedFlag) 
ENDMACRO() 

Und ich nenne es z.B. mit:

CheckAndAddFlag("-Wno-error=type-limits") 
CheckAndAddFlag("-Wfloat-conversion") 

Normalerweise sollte es nur einmal jedes Flag überprüfen, setzen Sie seine Variable und folgende Läufe von CMake diese finden sollten und es nicht wieder überprüfen (mit MSVC try_compile langsam ist schmerzlich)
Es funktioniert für die meisten Flags, aber es funktioniert nicht mit -Wno-error=type-limits. Hier wird das Flag entsprechend der Ausgabe doppelt überprüft. Daher habe ich die Variable _CHECKED hinzugefügt, um dies zu umgehen, aber auch das funktioniert nicht. Es wird erneut überprüft.

Einige Ausgang:

Checking CXX_FLAG__Werror=type_limits_SUPPORTED. Checked? _Werror=type_limits_CHECKED= end 
Performing Test CXX_FLAG__Werror=type_limits_SUPPORTED 
Performing Test CXX_FLAG__Werror=type_limits_SUPPORTED - Failed 
Performing Test C_FLAG__Werror=type_limits_SUPPORTED 
Performing Test C_FLAG__Werror=type_limits_SUPPORTED - Failed 
Checked CXX_FLAG__Werror=type_limits_SUPPORTED. Checked? _Werror=type_limits_CHECKED= YES end 
Checking CXX_FLAG__Wfloat_conversion_SUPPORTED. Checked? _Wfloat_conversion_CHECKED= YES end 
Checking CXX_FLAG__Wlong_long_SUPPORTED. Checked? _Wlong_long_CHECKED= YES end 

Irgendwelche Ideen, warum dies geschieht? Warum wird die Variable gesetzt, aber im nächsten CMAKE-Lauf nicht gesetzt und warum nur das?

Antwort

1

Sie verwirren CMake mit Ihren = Variablennamen anmelden?

Versuchen Sie stattdessen:

STRING(REGEX REPLACE "[-=]" "_" VarName ${VarName})