diff options
author | Brad King <brad.king@kitware.com> | 2020-09-10 14:56:32 (GMT) |
---|---|---|
committer | Brad King <brad.king@kitware.com> | 2020-09-14 14:48:16 (GMT) |
commit | b4fc4da903ad5c69cfbf693839ee5020c3f2ede6 (patch) | |
tree | d473e70256a9f5ec5dd34149bf3c1463f6c51de3 /Tests/RunCMake/ExternalProject/NO_DEPENDS.cmake | |
parent | f5791e24c63617901ae033c14d99c0e02d402b05 (diff) | |
download | CMake-b4fc4da903ad5c69cfbf693839ee5020c3f2ede6.zip CMake-b4fc4da903ad5c69cfbf693839ee5020c3f2ede6.tar.gz CMake-b4fc4da903ad5c69cfbf693839ee5020c3f2ede6.tar.bz2 |
ExternalProject: Add policy CMP0114 to refine step target dependencies
`ExternalProject_Add_StepTargets` and `INDEPENDENT_STEP_TARGETS` have
some limitations and lack some sanity checks. They can cause confusing
build systems to be generated. The basic problems are:
* The notion of step independence is attached to the step target
rather than the step itself.
* The custom commands implementing the steps are duplicated in the
step targets and the primary targets. This can cause races.
It is also incompatible with the Xcode "new build system".
Fix this by introducing policy CMP0114 to change the way step target
dependencies are handled. Define independence from external
dependencies as a property of each individual step regardless of whether
there is a target for it. Add dependencies among the primary target and
the step targets such that each custom command only appears in one
target. When some steps are disconnected from the primary target, add
step targets for the steps commonly depended upon so that there is a
place to hold their custom commands uniquely.
Fixes: #18663
Diffstat (limited to 'Tests/RunCMake/ExternalProject/NO_DEPENDS.cmake')
-rw-r--r-- | Tests/RunCMake/ExternalProject/NO_DEPENDS.cmake | 18 |
1 files changed, 0 insertions, 18 deletions
diff --git a/Tests/RunCMake/ExternalProject/NO_DEPENDS.cmake b/Tests/RunCMake/ExternalProject/NO_DEPENDS.cmake deleted file mode 100644 index 57626d6..0000000 --- a/Tests/RunCMake/ExternalProject/NO_DEPENDS.cmake +++ /dev/null @@ -1,18 +0,0 @@ -cmake_minimum_required(VERSION 2.8.12) - -include(ExternalProject RESULT_VARIABLE GOO) - -set_property(DIRECTORY PROPERTY EP_INDEPENDENT_STEP_TARGETS download patch update configure build) - -ExternalProject_Add(FOO - URL https://example.org/foo.tar.gz) - -ExternalProject_Add(BAR - URL https://example.org/bar.tar.gz - TEST_COMMAND echo test - INDEPENDENT_STEP_TARGETS install) -# This one should not give a warning -ExternalProject_Add_Step(BAR bar - COMMAND echo bar) - -ExternalProject_Add_StepTargets(BAR NO_DEPENDS test bar) |