diff options
author | Brad King <brad.king@kitware.com> | 2008-11-25 21:50:48 (GMT) |
---|---|---|
committer | Brad King <brad.king@kitware.com> | 2008-11-25 21:50:48 (GMT) |
commit | 0e03bd1ab4789081050761342d5fdf4aa9cf0824 (patch) | |
tree | ac9f35335124a8a3107b834a3689713d979bb850 /Source | |
parent | 47aa926523131ca59a64c6342b37c563d6a942f0 (diff) | |
download | CMake-0e03bd1ab4789081050761342d5fdf4aa9cf0824.zip CMake-0e03bd1ab4789081050761342d5fdf4aa9cf0824.tar.gz CMake-0e03bd1ab4789081050761342d5fdf4aa9cf0824.tar.bz2 |
BUG: Do not map install_name of imported targets
When we install a target on Mac, we generate a call to install_name_tool to fix
install_name entries in the target for shared libraries it links. This change
makes the step ignore entries for imported targets since their install_name
will not change and cmTarget cannot produce a mapping for them. This fixes the
error
GetLibraryNamesInternal called on imported target: kdelibs
seen by kde folks.
Diffstat (limited to 'Source')
-rw-r--r-- | Source/cmInstallTargetGenerator.cxx | 9 |
1 files changed, 8 insertions, 1 deletions
diff --git a/Source/cmInstallTargetGenerator.cxx b/Source/cmInstallTargetGenerator.cxx index 68dd586..fabcb0a 100644 --- a/Source/cmInstallTargetGenerator.cxx +++ b/Source/cmInstallTargetGenerator.cxx @@ -489,10 +489,17 @@ cmInstallTargetGenerator for(std::set<cmTarget*>::const_iterator j = sharedLibs.begin(); j != sharedLibs.end(); ++j) { + cmTarget* tgt = *j; + + // The install_name of an imported target does not change. + if(tgt->IsImported()) + { + continue; + } + // If the build tree and install tree use different path // components of the install_name field then we need to create a // mapping to be applied after installation. - cmTarget* tgt = *j; std::string for_build = tgt->GetInstallNameDirForBuildTree(config); std::string for_install = tgt->GetInstallNameDirForInstallTree(config); if(for_build != for_install) |