mirror of
https://github.com/Kitware/CMake.git
synced 2025-10-14 19:08:07 +08:00
VS: Remove the '/guard:cf' flag from v143 link flag table
Apply the change from commit db35e3cfd6
(VS: Fix support for '/guard:cf'
linker flag for v142, 2019-01-24, v3.14.0-rc1~74^2~2) to the v143 flag
table.
The entry for `LinkControlFlowGuard` in `v143_Link.json` does not work
when used in a `.vcxproj` file. Drop our link flag table entries for
this toolset so that the flag will be passed via `AdditionalOptions`.
Also add a test case.
This commit is contained in:

committed by
Brad King

parent
b8e0b40734
commit
9e24437c91
@@ -977,13 +977,6 @@
|
||||
"value": "true",
|
||||
"flags": []
|
||||
},
|
||||
{
|
||||
"name": "LinkControlFlowGuard",
|
||||
"switch": "guard:cf",
|
||||
"comment": "Control Flow Guard",
|
||||
"value": "true",
|
||||
"flags": []
|
||||
},
|
||||
{
|
||||
"name": "LinkGuardEHContMetadata",
|
||||
"switch": "guard:ehcont",
|
||||
|
@@ -41,6 +41,7 @@ run_cmake(VsDeployEnabled)
|
||||
run_cmake(VsSettings)
|
||||
run_cmake(VsSourceSettingsTool)
|
||||
run_cmake(VsPlatformToolset)
|
||||
run_cmake(VsControlFlowGuardLinkSetting)
|
||||
|
||||
run_cmake(VsWinRTByDefault)
|
||||
|
||||
|
@@ -0,0 +1,40 @@
|
||||
set(vcProjectFile "${RunCMake_TEST_BINARY_DIR}/ControlFlowGuardProject.vcxproj")
|
||||
if(NOT EXISTS "${vcProjectFile}")
|
||||
set(RunCMake_TEST_FAILED "Project file ControlFlowGuardProject.vcxproj does not exist.")
|
||||
return()
|
||||
endif()
|
||||
|
||||
set(Is_in_link_section 0)
|
||||
set(HAS_ControlFlowGuardSetting 0)
|
||||
|
||||
file(STRINGS "${vcProjectFile}" lines)
|
||||
foreach(line IN LISTS lines)
|
||||
if(line MATCHES "^ *<LinkControlFlowGuard>([^<>]+)</LinkControlFlowGuard>")
|
||||
set(RunCMake_TEST_FAILED "Project file ControlFlowGuardProject.vcxproj contains the invalid <LinkControlFlowGuard> link property.")
|
||||
return()
|
||||
break()
|
||||
endif()
|
||||
if(line MATCHES "^ *<Link>")
|
||||
# The start of the link section of the vcxproj file
|
||||
set(Is_in_link_section 1)
|
||||
continue()
|
||||
endif()
|
||||
if(line MATCHES "^ *</Link>")
|
||||
# The end of the link section of the vcxproj file
|
||||
set(Is_in_link_section 0)
|
||||
continue()
|
||||
endif()
|
||||
if(Is_in_link_section)
|
||||
if(line MATCHES "^ *<AdditionalOptions>([^<>]+)</AdditionalOptions>")
|
||||
if("${CMAKE_MATCH_1}" MATCHES ".*/guard:cf.*")
|
||||
set(HAS_ControlFlowGuardSetting 1)
|
||||
break()
|
||||
endif()
|
||||
endif()
|
||||
endif()
|
||||
endforeach()
|
||||
|
||||
if(NOT HAS_ControlFlowGuardSetting)
|
||||
set(RunCMake_TEST_FAILED "Project file ControlFlowGuardProject.vcxproj does not have '/guard:cf' specified in the <AdditionalOptions> property.")
|
||||
return()
|
||||
endif()
|
@@ -0,0 +1,7 @@
|
||||
enable_language(CXX)
|
||||
|
||||
# Add the Control Flow Guard compiler and linker option
|
||||
add_compile_options("/guard:cf")
|
||||
string(APPEND CMAKE_SHARED_LINKER_FLAGS " /guard:cf")
|
||||
|
||||
add_library(ControlFlowGuardProject SHARED foo.cpp)
|
Reference in New Issue
Block a user