summaryrefslogtreecommitdiffstats
path: root/Source/cmInstallCommand.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'Source/cmInstallCommand.cxx')
-rw-r--r--Source/cmInstallCommand.cxx59
1 files changed, 36 insertions, 23 deletions
diff --git a/Source/cmInstallCommand.cxx b/Source/cmInstallCommand.cxx
index a15b656..62d3579 100644
--- a/Source/cmInstallCommand.cxx
+++ b/Source/cmInstallCommand.cxx
@@ -410,6 +410,10 @@ bool cmInstallCommand::HandleTargetsMode(std::vector<std::string> const& args)
{
// Handle each target type.
cmTarget& target = *(*ti);
+ cmInstallTargetGenerator* archiveGenerator = 0;
+ cmInstallTargetGenerator* runtimeGenerator = 0;
+ cmInstallTargetGenerator* libraryGenerator = 0;
+
switch(target.GetType())
{
case cmTarget::SHARED_LIBRARY:
@@ -424,23 +428,24 @@ bool cmInstallCommand::HandleTargetsMode(std::vector<std::string> const& args)
if(archive_destination)
{
// The import library uses the ARCHIVE properties.
- this->Makefile->AddInstallGenerator(
- new cmInstallTargetGenerator(target, archive_dest.c_str(), true,
+ archiveGenerator = new cmInstallTargetGenerator(target,
+ archive_dest.c_str(),
+ true,
archive_permissions.c_str(),
archive_configurations,
archive_component.c_str(),
- archive_optional));
+ archive_optional);
}
if(runtime_destination)
{
// The DLL uses the RUNTIME properties.
- this->Makefile->AddInstallGenerator(
- new cmInstallTargetGenerator(target, runtime_dest.c_str(),
+ runtimeGenerator = new cmInstallTargetGenerator(target,
+ runtime_dest.c_str(),
false,
runtime_permissions.c_str(),
runtime_configurations,
runtime_component.c_str(),
- runtime_optional));
+ runtime_optional);
}
}
else
@@ -449,13 +454,13 @@ bool cmInstallCommand::HandleTargetsMode(std::vector<std::string> const& args)
if(library_destination)
{
// The shared library uses the LIBRARY properties.
- this->Makefile->AddInstallGenerator(
- new cmInstallTargetGenerator(target, library_dest.c_str(),
+ libraryGenerator = new cmInstallTargetGenerator(target,
+ library_dest.c_str(),
false,
library_permissions.c_str(),
library_configurations,
library_component.c_str(),
- library_optional));
+ library_optional);
}
else
{
@@ -473,12 +478,13 @@ bool cmInstallCommand::HandleTargetsMode(std::vector<std::string> const& args)
// Static libraries use ARCHIVE properties.
if(archive_destination)
{
- this->Makefile->AddInstallGenerator(
- new cmInstallTargetGenerator(target, archive_dest.c_str(), false,
+ archiveGenerator = new cmInstallTargetGenerator(target,
+ archive_dest.c_str(),
+ false,
archive_permissions.c_str(),
archive_configurations,
archive_component.c_str(),
- archive_optional));
+ archive_optional);
}
else
{
@@ -495,12 +501,13 @@ bool cmInstallCommand::HandleTargetsMode(std::vector<std::string> const& args)
// Modules use LIBRARY properties.
if(library_destination)
{
- this->Makefile->AddInstallGenerator(
- new cmInstallTargetGenerator(target, library_dest.c_str(), false,
+ libraryGenerator = new cmInstallTargetGenerator(target,
+ library_dest.c_str(),
+ false,
library_permissions.c_str(),
library_configurations,
library_component.c_str(),
- library_optional));
+ library_optional);
}
else
{
@@ -517,12 +524,13 @@ bool cmInstallCommand::HandleTargetsMode(std::vector<std::string> const& args)
// Executables use the RUNTIME properties.
if(runtime_destination)
{
- this->Makefile->AddInstallGenerator(
- new cmInstallTargetGenerator(target, runtime_dest.c_str(), false,
+ runtimeGenerator = new cmInstallTargetGenerator(target,
+ runtime_dest.c_str(),
+ false,
runtime_permissions.c_str(),
runtime_configurations,
runtime_component.c_str(),
- runtime_optional));
+ runtime_optional);
}
else
{
@@ -539,12 +547,13 @@ bool cmInstallCommand::HandleTargetsMode(std::vector<std::string> const& args)
if(dll_platform && archive_destination)
{
// The import library uses the ARCHIVE properties.
- this->Makefile->AddInstallGenerator(
- new cmInstallTargetGenerator(target, archive_dest.c_str(), true,
+ archiveGenerator = new cmInstallTargetGenerator(target,
+ archive_dest.c_str(),
+ true,
archive_permissions.c_str(),
archive_configurations,
archive_component.c_str(),
- true));
+ true);
}
}
break;
@@ -553,6 +562,10 @@ bool cmInstallCommand::HandleTargetsMode(std::vector<std::string> const& args)
// Ignore the case.
break;
}
+ this->Makefile->AddInstallGenerator(archiveGenerator);
+ this->Makefile->AddInstallGenerator(runtimeGenerator);
+ this->Makefile->AddInstallGenerator(libraryGenerator);
+
}
// Tell the global generator about any installation component names
@@ -1114,7 +1127,7 @@ cmInstallCommand::HandleDirectoryMode(std::vector<std::string> const& args)
//----------------------------------------------------------------------------
void cmInstallCommand::ComputeDestination(const char* destination,
- std::string& dest)
+ std::string& dest) const
{
if(destination)
{
@@ -1142,7 +1155,7 @@ void cmInstallCommand::ComputeDestination(const char* destination,
//----------------------------------------------------------------------------
bool cmInstallCommand::CheckPermissions(std::string const& arg,
- std::string& permissions)
+ std::string& permissions) const
{
// Table of valid permissions.
const char* table[] =