summaryrefslogtreecommitdiffstats
path: root/Source/cmInstallCommand.cxx
diff options
context:
space:
mode:
Diffstat (limited to 'Source/cmInstallCommand.cxx')
-rw-r--r--Source/cmInstallCommand.cxx242
1 files changed, 206 insertions, 36 deletions
diff --git a/Source/cmInstallCommand.cxx b/Source/cmInstallCommand.cxx
index 5de168b..4ff5c63 100644
--- a/Source/cmInstallCommand.cxx
+++ b/Source/cmInstallCommand.cxx
@@ -144,23 +144,35 @@ bool cmInstallCommand::HandleTargetsMode(std::vector<std::string> const& args)
bool archive_settings = true;
bool library_settings = true;
bool runtime_settings = true;
+ bool framework_settings = true;
+ bool bundle_settings = true;
std::vector<cmTarget*> targets;
const char* archive_destination = 0;
const char* library_destination = 0;
const char* runtime_destination = 0;
+ const char* framework_destination = 0;
+ const char* bundle_destination = 0;
std::string archive_permissions;
std::string library_permissions;
std::string runtime_permissions;
+ std::string framework_permissions;
+ std::string bundle_permissions;
std::string archive_component = "Unspecified";
std::string library_component = "Unspecified";
std::string runtime_component = "Unspecified";
+ std::string framework_component = "Unspecified";
+ std::string bundle_component = "Unspecified";
std::string exportName;
std::vector<std::string> archive_configurations;
std::vector<std::string> library_configurations;
std::vector<std::string> runtime_configurations;
+ std::vector<std::string> framework_configurations;
+ std::vector<std::string> bundle_configurations;
bool archive_optional = false;
bool library_optional = false;
bool runtime_optional = false;
+ bool framework_optional = false;
+ bool bundle_optional = false;
for(unsigned int i=1; i < args.size(); ++i)
{
if(args[i] == "DESTINATION")
@@ -215,6 +227,8 @@ bool cmInstallCommand::HandleTargetsMode(std::vector<std::string> const& args)
archive_settings = true;
library_settings = false;
runtime_settings = false;
+ framework_settings = false;
+ bundle_settings = false;
}
else if(args[i] == "LIBRARY")
{
@@ -228,6 +242,8 @@ bool cmInstallCommand::HandleTargetsMode(std::vector<std::string> const& args)
archive_settings = false;
library_settings = true;
runtime_settings = false;
+ framework_settings = false;
+ bundle_settings = false;
}
else if(args[i] == "RUNTIME")
{
@@ -241,10 +257,42 @@ bool cmInstallCommand::HandleTargetsMode(std::vector<std::string> const& args)
archive_settings = false;
library_settings = false;
runtime_settings = true;
+ framework_settings = false;
+ bundle_settings = false;
+ }
+ else if(args[i] == "FRAMEWORK")
+ {
+ // Switch to setting only framework properties.
+ doing_targets = false;
+ doing_destination = false;
+ doing_permissions = false;
+ doing_component = false;
+ doing_configurations = false;
+ doing_export = false;
+ archive_settings = false;
+ library_settings = false;
+ runtime_settings = false;
+ framework_settings = true;
+ bundle_settings = false;
+ }
+ else if(args[i] == "BUNDLE")
+ {
+ // Switch to setting only bundle properties.
+ doing_targets = false;
+ doing_destination = false;
+ doing_permissions = false;
+ doing_component = false;
+ doing_configurations = false;
+ doing_export = false;
+ archive_settings = false;
+ library_settings = false;
+ runtime_settings = false;
+ framework_settings = false;
+ bundle_settings = true;
}
else if(args[i] == "EXPORT")
{
- // Switch to setting only runtime properties.
+ // Switch to setting the export property.
doing_targets = false;
doing_destination = false;
doing_permissions = false;
@@ -272,6 +320,14 @@ bool cmInstallCommand::HandleTargetsMode(std::vector<std::string> const& args)
{
runtime_optional = true;
}
+ if(framework_settings)
+ {
+ framework_optional = true;
+ }
+ if(bundle_settings)
+ {
+ bundle_optional = true;
+ }
}
else if(doing_targets)
{
@@ -319,6 +375,14 @@ bool cmInstallCommand::HandleTargetsMode(std::vector<std::string> const& args)
{
runtime_destination = args[i].c_str();
}
+ if(framework_settings)
+ {
+ framework_destination = args[i].c_str();
+ }
+ if(bundle_settings)
+ {
+ bundle_destination = args[i].c_str();
+ }
doing_destination = false;
}
else if(doing_component)
@@ -336,6 +400,14 @@ bool cmInstallCommand::HandleTargetsMode(std::vector<std::string> const& args)
{
runtime_component = args[i];
}
+ if(framework_settings)
+ {
+ framework_component = args[i];
+ }
+ if(bundle_settings)
+ {
+ bundle_component = args[i];
+ }
doing_component = false;
}
else if(doing_permissions)
@@ -377,6 +449,30 @@ bool cmInstallCommand::HandleTargetsMode(std::vector<std::string> const& args)
return false;
}
}
+ if(framework_settings)
+ {
+ // Check the requested permission.
+ if(!this->CheckPermissions(args[i], framework_permissions))
+ {
+ cmOStringStream e;
+ e << args[0] << " given invalid permission \""
+ << args[i] << "\".";
+ this->SetError(e.str().c_str());
+ return false;
+ }
+ }
+ if(bundle_settings)
+ {
+ // Check the requested permission.
+ if(!this->CheckPermissions(args[i], bundle_permissions))
+ {
+ cmOStringStream e;
+ e << args[0] << " given invalid permission \""
+ << args[i] << "\".";
+ this->SetError(e.str().c_str());
+ return false;
+ }
+ }
}
else if(doing_configurations)
{
@@ -393,6 +489,14 @@ bool cmInstallCommand::HandleTargetsMode(std::vector<std::string> const& args)
{
runtime_configurations.push_back(args[i]);
}
+ if(framework_settings)
+ {
+ framework_configurations.push_back(args[i]);
+ }
+ if(bundle_settings)
+ {
+ bundle_configurations.push_back(args[i]);
+ }
}
else if(doing_export)
{
@@ -414,7 +518,8 @@ bool cmInstallCommand::HandleTargetsMode(std::vector<std::string> const& args)
{
return true;
}
- if(!archive_destination && !library_destination && !runtime_destination)
+ if(!archive_destination && !library_destination && !runtime_destination &&
+ !framework_destination && !bundle_destination)
{
this->SetError("TARGETS given no DESTINATION!");
return false;
@@ -429,9 +534,13 @@ bool cmInstallCommand::HandleTargetsMode(std::vector<std::string> const& args)
std::string archive_dest;
std::string library_dest;
std::string runtime_dest;
+ std::string framework_dest;
+ std::string bundle_dest;
this->ComputeDestination(archive_destination, archive_dest);
this->ComputeDestination(library_destination, library_dest);
this->ComputeDestination(runtime_destination, runtime_dest);
+ if(framework_destination) framework_dest = framework_destination;
+ if(bundle_destination) bundle_dest = bundle_destination;
// Generate install script code to install the given targets.
for(std::vector<cmTarget*>::iterator ti = targets.begin();
@@ -440,8 +549,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;
+ cmInstallTargetGenerator* runtimeGenerator = 0;
+ cmInstallTargetGenerator* frameworkGenerator = 0;
+ cmInstallTargetGenerator* bundleGenerator = 0;
switch(target.GetType())
{
@@ -480,24 +591,51 @@ bool cmInstallCommand::HandleTargetsMode(std::vector<std::string> const& args)
else
{
// This is a non-DLL platform.
- if(library_destination)
+ // If it is marked with FRAMEWORK property use the FRAMEWORK set of
+ // INSTALL properties. Otherwise, use the LIBRARY properties.
+ if(target.GetPropertyAsBool("FRAMEWORK"))
{
- // The shared library uses the LIBRARY properties.
- libraryGenerator = new cmInstallTargetGenerator(target,
- library_dest.c_str(),
- false,
- library_permissions.c_str(),
- library_configurations,
- library_component.c_str(),
- library_optional);
+ if(framework_destination)
+ {
+ // Use the FRAMEWORK properties.
+ frameworkGenerator = new cmInstallTargetGenerator(target,
+ framework_dest.c_str(),
+ false,
+ framework_permissions.c_str(),
+ framework_configurations,
+ framework_component.c_str(),
+ framework_optional);
+ }
+ else
+ {
+ cmOStringStream e;
+ e << "TARGETS given no FRAMEWORK DESTINATION for shared library "
+ "FRAMEWORK target \"" << target.GetName() << "\".";
+ this->SetError(e.str().c_str());
+ return false;
+ }
}
else
{
- cmOStringStream e;
- e << "TARGETS given no LIBRARY DESTINATION for shared library "
- "target \"" << target.GetName() << "\".";
- this->SetError(e.str().c_str());
- return false;
+ if(library_destination)
+ {
+ // The shared library uses the LIBRARY properties.
+ libraryGenerator = new cmInstallTargetGenerator(target,
+ library_dest.c_str(),
+ false,
+ library_permissions.c_str(),
+ library_configurations,
+ library_component.c_str(),
+ library_optional);
+ }
+ else
+ {
+ cmOStringStream e;
+ e << "TARGETS given no LIBRARY DESTINATION for shared library "
+ "target \"" << target.GetName() << "\".";
+ this->SetError(e.str().c_str());
+ return false;
+ }
}
}
}
@@ -507,8 +645,8 @@ bool cmInstallCommand::HandleTargetsMode(std::vector<std::string> const& args)
// Static libraries use ARCHIVE properties.
if(archive_destination)
{
- archiveGenerator = new cmInstallTargetGenerator(target,
- archive_dest.c_str(),
+ archiveGenerator = new cmInstallTargetGenerator(target,
+ archive_dest.c_str(),
false,
archive_permissions.c_str(),
archive_configurations,
@@ -551,23 +689,47 @@ bool cmInstallCommand::HandleTargetsMode(std::vector<std::string> const& args)
case cmTarget::EXECUTABLE:
{
// Executables use the RUNTIME properties.
- if(runtime_destination)
+ if(target.GetPropertyAsBool("MACOSX_BUNDLE"))
{
- runtimeGenerator = new cmInstallTargetGenerator(target,
- runtime_dest.c_str(),
- false,
- runtime_permissions.c_str(),
- runtime_configurations,
- runtime_component.c_str(),
- runtime_optional);
+ if(bundle_destination)
+ {
+ bundleGenerator = new cmInstallTargetGenerator(target,
+ bundle_dest.c_str(),
+ false,
+ bundle_permissions.c_str(),
+ bundle_configurations,
+ bundle_component.c_str(),
+ bundle_optional);
+ }
+ else
+ {
+ cmOStringStream e;
+ e << "TARGETS given no BUNDLE DESTINATION for MACOSX_BUNDLE executable target \""
+ << target.GetName() << "\".";
+ this->SetError(e.str().c_str());
+ return false;
+ }
}
else
{
- cmOStringStream e;
- e << "TARGETS given no RUNTIME DESTINATION for executable target \""
- << target.GetName() << "\".";
- this->SetError(e.str().c_str());
- return false;
+ if(runtime_destination)
+ {
+ runtimeGenerator = new cmInstallTargetGenerator(target,
+ runtime_dest.c_str(),
+ false,
+ runtime_permissions.c_str(),
+ runtime_configurations,
+ runtime_component.c_str(),
+ runtime_optional);
+ }
+ else
+ {
+ cmOStringStream e;
+ e << "TARGETS given no RUNTIME DESTINATION for executable target \""
+ << target.GetName() << "\".";
+ this->SetError(e.str().c_str());
+ return false;
+ }
}
// On DLL platforms an executable may also have an import
@@ -577,8 +739,8 @@ bool cmInstallCommand::HandleTargetsMode(std::vector<std::string> const& args)
target.GetPropertyAsBool("ENABLE_EXPORTS"))
{
// The import library uses the ARCHIVE properties.
- archiveGenerator = new cmInstallTargetGenerator(target,
- archive_dest.c_str(),
+ archiveGenerator = new cmInstallTargetGenerator(target,
+ archive_dest.c_str(),
true,
archive_permissions.c_str(),
archive_configurations,
@@ -593,8 +755,10 @@ bool cmInstallCommand::HandleTargetsMode(std::vector<std::string> const& args)
break;
}
this->Makefile->AddInstallGenerator(archiveGenerator);
- this->Makefile->AddInstallGenerator(runtimeGenerator);
this->Makefile->AddInstallGenerator(libraryGenerator);
+ this->Makefile->AddInstallGenerator(runtimeGenerator);
+ this->Makefile->AddInstallGenerator(frameworkGenerator);
+ this->Makefile->AddInstallGenerator(bundleGenerator);
if (!exportName.empty())
{
@@ -603,7 +767,9 @@ bool cmInstallCommand::HandleTargetsMode(std::vector<std::string> const& args)
&target,
archiveGenerator,
runtimeGenerator,
- libraryGenerator);
+ libraryGenerator,
+ frameworkGenerator,
+ bundleGenerator);
}
}
@@ -615,6 +781,10 @@ bool cmInstallCommand::HandleTargetsMode(std::vector<std::string> const& args)
->AddInstallComponent(library_component.c_str());
this->Makefile->GetLocalGenerator()->GetGlobalGenerator()
->AddInstallComponent(runtime_component.c_str());
+ this->Makefile->GetLocalGenerator()->GetGlobalGenerator()
+ ->AddInstallComponent(framework_component.c_str());
+ this->Makefile->GetLocalGenerator()->GetGlobalGenerator()
+ ->AddInstallComponent(bundle_component.c_str());
return true;
}