mirror of
https://github.com/google/benchmark.git
synced 2024-12-26 20:40:21 +08:00
fix cmake issue with referencing a non-existing function argument (#1118)
according to https://cmake.org/cmake/help/latest/command/function.html, "Referencing to ARGV# arguments beyond ARGC have undefined behavior.", which I hit with cmake 3.19.7. This uses ARGC to check whether ARGV1 has been passed before referencing it.
This commit is contained in:
parent
058fb588b6
commit
d882be1ea9
@ -34,9 +34,11 @@ function(add_cxx_compiler_flag FLAG)
|
|||||||
check_cxx_compiler_flag("${FLAG}" ${MANGLED_FLAG})
|
check_cxx_compiler_flag("${FLAG}" ${MANGLED_FLAG})
|
||||||
set(CMAKE_REQUIRED_FLAGS "${OLD_CMAKE_REQUIRED_FLAGS}")
|
set(CMAKE_REQUIRED_FLAGS "${OLD_CMAKE_REQUIRED_FLAGS}")
|
||||||
if(${MANGLED_FLAG})
|
if(${MANGLED_FLAG})
|
||||||
set(VARIANT ${ARGV1})
|
if(ARGC GREATER 1)
|
||||||
if(ARGV1)
|
set(VARIANT ${ARGV1})
|
||||||
string(TOUPPER "_${VARIANT}" VARIANT)
|
string(TOUPPER "_${VARIANT}" VARIANT)
|
||||||
|
else()
|
||||||
|
set(VARIANT "")
|
||||||
endif()
|
endif()
|
||||||
set(CMAKE_CXX_FLAGS${VARIANT} "${CMAKE_CXX_FLAGS${VARIANT}} ${BENCHMARK_CXX_FLAGS${VARIANT}} ${FLAG}" PARENT_SCOPE)
|
set(CMAKE_CXX_FLAGS${VARIANT} "${CMAKE_CXX_FLAGS${VARIANT}} ${BENCHMARK_CXX_FLAGS${VARIANT}} ${FLAG}" PARENT_SCOPE)
|
||||||
endif()
|
endif()
|
||||||
@ -49,9 +51,11 @@ function(add_required_cxx_compiler_flag FLAG)
|
|||||||
check_cxx_compiler_flag("${FLAG}" ${MANGLED_FLAG})
|
check_cxx_compiler_flag("${FLAG}" ${MANGLED_FLAG})
|
||||||
set(CMAKE_REQUIRED_FLAGS "${OLD_CMAKE_REQUIRED_FLAGS}")
|
set(CMAKE_REQUIRED_FLAGS "${OLD_CMAKE_REQUIRED_FLAGS}")
|
||||||
if(${MANGLED_FLAG})
|
if(${MANGLED_FLAG})
|
||||||
set(VARIANT ${ARGV1})
|
if(ARGC GREATER 1)
|
||||||
if(ARGV1)
|
set(VARIANT ${ARGV1})
|
||||||
string(TOUPPER "_${VARIANT}" VARIANT)
|
string(TOUPPER "_${VARIANT}" VARIANT)
|
||||||
|
else()
|
||||||
|
set(VARIANT "")
|
||||||
endif()
|
endif()
|
||||||
set(CMAKE_CXX_FLAGS${VARIANT} "${CMAKE_CXX_FLAGS${VARIANT}} ${FLAG}" PARENT_SCOPE)
|
set(CMAKE_CXX_FLAGS${VARIANT} "${CMAKE_CXX_FLAGS${VARIANT}} ${FLAG}" PARENT_SCOPE)
|
||||||
set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} ${FLAG}" PARENT_SCOPE)
|
set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} ${FLAG}" PARENT_SCOPE)
|
||||||
|
Loading…
Reference in New Issue
Block a user