summaryrefslogtreecommitdiffstats
path: root/Source/cmTarget.cxx
diff options
context:
space:
mode:
authorBrad King <brad.king@kitware.com>2007-03-09 14:30:16 (GMT)
committerBrad King <brad.king@kitware.com>2007-03-09 14:30:16 (GMT)
commit528f60f4a60440097a4a4997cdf59f0e564ba370 (patch)
treeaa22bf1a28cf33e62664cac46a33c43f0727a70f /Source/cmTarget.cxx
parent3ec0ff05de74dc2a51461b0345d0d0e6fe0786b6 (diff)
downloadCMake-528f60f4a60440097a4a4997cdf59f0e564ba370.zip
CMake-528f60f4a60440097a4a4997cdf59f0e564ba370.tar.gz
CMake-528f60f4a60440097a4a4997cdf59f0e564ba370.tar.bz2
ENH: Added implib option to cmTarget::GetDirectory to support a separate directory containing the import library. This is an incremental step for bug#4210.
Diffstat (limited to 'Source/cmTarget.cxx')
-rw-r--r--Source/cmTarget.cxx21
1 files changed, 15 insertions, 6 deletions
diff --git a/Source/cmTarget.cxx b/Source/cmTarget.cxx
index f3e59e5..47e8a90 100644
--- a/Source/cmTarget.cxx
+++ b/Source/cmTarget.cxx
@@ -661,7 +661,7 @@ const std::vector<std::string>& cmTarget::GetLinkDirectories()
// Add the directory only if it is not already present. This
// is an N^2 algorithm for adding the directories, but N
// should not get very big.
- const char* libpath = tgt->GetDirectory();
+ const char* libpath = tgt->GetDirectory(0, true);
if(std::find(this->LinkDirectories.begin(),
this->LinkDirectories.end(),
libpath) == this->LinkDirectories.end())
@@ -1091,11 +1091,11 @@ void cmTarget::SetProperty(const char* prop, const char* value)
this->Properties.SetProperty(prop, value, cmProperty::TARGET);
}
-const char* cmTarget::GetDirectory(const char* config)
+const char* cmTarget::GetDirectory(const char* config, bool implib)
{
if(config)
{
- this->Directory = this->GetOutputDir();
+ this->Directory = this->GetOutputDir(implib);
// Add the configuration's subdirectory.
this->Makefile->GetLocalGenerator()->GetGlobalGenerator()->
AppendDirectoryForConfig("/", config, "", this->Directory);
@@ -1103,7 +1103,7 @@ const char* cmTarget::GetDirectory(const char* config)
}
else
{
- return this->GetOutputDir();
+ return this->GetOutputDir(implib);
}
}
@@ -1446,7 +1446,7 @@ void cmTarget::GetFullName(std::string& prefix, std::string& base,
std::string cmTarget::GetFullPath(const char* config, bool implib)
{
// Start with the output directory for the target.
- std::string fpath = this->GetDirectory(config);
+ std::string fpath = this->GetDirectory(config, implib);
fpath += "/";
// Add the full name of the target.
@@ -1935,8 +1935,17 @@ std::string cmTarget::GetInstallNameDirForInstallTree(const char*)
}
//----------------------------------------------------------------------------
-const char* cmTarget::GetOutputDir()
+const char* cmTarget::GetOutputDir(bool implib)
{
+ // The implib option is only allowed for shared libraries.
+ if(this->GetType() != cmTarget::SHARED_LIBRARY)
+ {
+ implib = false;
+ }
+
+ // For now the import library is always in the same directory as the DLL.
+ static_cast<void>(implib);
+
if(this->OutputDir.empty())
{
// Lookup the output path for this target type.