summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Source/cmExportLibraryDependencies.cxx19
-rw-r--r--Source/cmExportLibraryDependencies.h17
2 files changed, 30 insertions, 6 deletions
diff --git a/Source/cmExportLibraryDependencies.cxx b/Source/cmExportLibraryDependencies.cxx
index ac9df30..cd36e06 100644
--- a/Source/cmExportLibraryDependencies.cxx
+++ b/Source/cmExportLibraryDependencies.cxx
@@ -80,8 +80,8 @@ void cmExportLibraryDependenciesCommand::ConstFinalPass() const
// Collect dependency information about all library targets built in
// the project.
- const cmake* cm = this->Makefile->GetCMakeInstance();
- const cmGlobalGenerator* global = cm->GetGlobalGenerator();
+ cmake* cm = this->Makefile->GetCMakeInstance();
+ cmGlobalGenerator* global = cm->GetGlobalGenerator();
const std::vector<cmLocalGenerator *>& locals = global->GetLocalGenerators();
std::map<cmStdString, cmStdString> libDepsOld;
std::map<cmStdString, cmStdString> libDepsNew;
@@ -137,9 +137,20 @@ void cmExportLibraryDependenciesCommand::ConstFinalPass() const
ltValue = "optimized";
break;
}
- valueOld += li->first;
+ std::string lib = li->first;
+ if(cmTarget* libtgt = global->FindTarget(0, lib.c_str()))
+ {
+ // Handle simple output name changes. This command is
+ // deprecated so we do not support full target name
+ // translation (which requires per-configuration info).
+ if(const char* outname = libtgt->GetProperty("OUTPUT_NAME"))
+ {
+ lib = outname;
+ }
+ }
+ valueOld += lib;
valueOld += ";";
- valueNew += li->first;
+ valueNew += lib;
valueNew += ";";
std::string& ltEntry = libTypes[ltVar];
diff --git a/Source/cmExportLibraryDependencies.h b/Source/cmExportLibraryDependencies.h
index 6fa92d0..b5997cc 100644
--- a/Source/cmExportLibraryDependencies.h
+++ b/Source/cmExportLibraryDependencies.h
@@ -59,8 +59,7 @@ public:
*/
virtual const char* GetTerseDocumentation()
{
- return
- "Write out the dependency information for all targets of a project.";
+ return "Deprecated. Use INSTALL(EXPORT) or EXPORT command.";
}
/**
@@ -69,6 +68,14 @@ public:
virtual const char* GetFullDocumentation()
{
return
+ "This command generates an old-style library dependencies file. "
+ "Projects requiring CMake 2.6 or later should not use the command. "
+ "Use instead the install(EXPORT) command to help export targets "
+ "from an installation tree and the export() command to export targets "
+ "from a build tree.\n"
+ "The old-style library dependencies file does not take into account "
+ "per-configuration names of libraries or the LINK_INTERFACE_LIBRARIES "
+ "target property.\n"
" export_library_dependencies(<file> [APPEND])\n"
"Create a file named <file> that can be included into a CMake listfile "
"with the INCLUDE command. The file will contain a number of SET "
@@ -78,6 +85,12 @@ public:
"specified, the SET commands will be appended to the given file "
"instead of replacing it.";
}
+
+ /** This command is kept for compatibility with older CMake versions. */
+ virtual bool IsDiscouraged()
+ {
+ return true;
+ }
cmTypeMacro(cmExportLibraryDependenciesCommand, cmCommand);