macOS: Restore compatibility for setting FRAMEWORK after install()
The `FRAMEWORK` target property affects the way the `install()` command
treats the target and so should be set first. Our implementation
assumed that this was always the case and led to an assertion failure.
Prior to CMake 3.12 this was visible only when using an explicit
`LIBRARY ... NAMELINK_ONLY` option, but commit 0212d7c762
(install: add
NAMELINK_COMPONENT argument, 2018-04-18, v3.12.0-rc1~139^2~3) made
it possible with a simple `LIBRARY DESTINATION`.
Fully supporting out-of-order specification will require non-trivial
refactoring to defer install generator creation to generate time.
For now simply restore the old behavior of installing the framework
to the library destination.
Fixes: #18848
This commit is contained in:
parent
8887ebc69b
commit
d9dd68cb60
@ -210,8 +210,29 @@ void cmInstallTargetGenerator::GenerateScriptForConfig(
|
||||
// An import library looks like a static library.
|
||||
type = cmInstallType_STATIC_LIBRARY;
|
||||
} else if (this->Target->IsFrameworkOnApple()) {
|
||||
// There is a bug in cmInstallCommand if this fails.
|
||||
assert(this->NamelinkMode == NamelinkModeNone);
|
||||
// FIXME: In principle we should be able to
|
||||
// assert(this->NamelinkMode == NamelinkModeNone);
|
||||
// but since the current install() command implementation checks
|
||||
// the FRAMEWORK property immediately instead of delaying until
|
||||
// generate time, it is possible for project code to set the
|
||||
// property after calling install(). In such a case, the install()
|
||||
// command will use the LIBRARY code path and create two install
|
||||
// generators, one for the namelink component (NamelinkModeOnly)
|
||||
// and one for the primary artifact component (NamelinkModeSkip).
|
||||
// Historically this was not diagnosed and resulted in silent
|
||||
// installation of a framework to the LIBRARY destination.
|
||||
// Retain that behavior.
|
||||
switch (this->NamelinkMode) {
|
||||
case NamelinkModeNone:
|
||||
// Normal case.
|
||||
break;
|
||||
case NamelinkModeOnly:
|
||||
// Assume the NamelinkModeSkip instance will install.
|
||||
return;
|
||||
case NamelinkModeSkip: {
|
||||
// Proceed to install in the LIBRARY destination for compatibility.
|
||||
} break;
|
||||
}
|
||||
|
||||
// Install the whole framework directory.
|
||||
type = cmInstallType_DIRECTORY;
|
||||
|
5
Tests/RunCMake/Framework/InstallBeforeFramework.cmake
Normal file
5
Tests/RunCMake/Framework/InstallBeforeFramework.cmake
Normal file
@ -0,0 +1,5 @@
|
||||
enable_language(C)
|
||||
|
||||
add_library(foo SHARED foo.c)
|
||||
install(TARGETS foo LIBRARY DESTINATION lib)
|
||||
set_property(TARGET foo PROPERTY FRAMEWORK TRUE)
|
@ -1,5 +1,7 @@
|
||||
include(RunCMake)
|
||||
|
||||
run_cmake(InstallBeforeFramework)
|
||||
|
||||
function(framework_layout_test Name Toolchain Type)
|
||||
set(RunCMake_TEST_BINARY_DIR ${RunCMake_BINARY_DIR}/${Toolchain}${Type}FrameworkLayout-build)
|
||||
set(RunCMake_TEST_NO_CLEAN 1)
|
||||
|
Loading…
Reference in New Issue
Block a user