diff options
Diffstat (limited to 'Source/cmInstallDirectoryGenerator.cxx')
-rw-r--r-- | Source/cmInstallDirectoryGenerator.cxx | 97 |
1 files changed, 97 insertions, 0 deletions
diff --git a/Source/cmInstallDirectoryGenerator.cxx b/Source/cmInstallDirectoryGenerator.cxx new file mode 100644 index 0000000..3928231 --- /dev/null +++ b/Source/cmInstallDirectoryGenerator.cxx @@ -0,0 +1,97 @@ +/*============================================================================ + CMake - Cross Platform Makefile Generator + Copyright 2000-2009 Kitware, Inc., Insight Software Consortium + + Distributed under the OSI-approved BSD License (the "License"); + see accompanying file Copyright.txt for details. + + This software is distributed WITHOUT ANY WARRANTY; without even the + implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. + See the License for more information. +============================================================================*/ +#include "cmInstallDirectoryGenerator.h" + +#include "cmGeneratorExpression.h" +#include "cmLocalGenerator.h" + +cmInstallDirectoryGenerator::cmInstallDirectoryGenerator( + std::vector<std::string> const& dirs, const char* dest, + const char* file_permissions, const char* dir_permissions, + std::vector<std::string> const& configurations, const char* component, + MessageLevel message, bool exclude_from_all, const char* literal_args, + bool optional) + : cmInstallGenerator(dest, configurations, component, message, + exclude_from_all) + , LocalGenerator(CM_NULLPTR) + , Directories(dirs) + , FilePermissions(file_permissions) + , DirPermissions(dir_permissions) + , LiteralArguments(literal_args) + , Optional(optional) +{ + // We need per-config actions if destination have generator expressions. + if (cmGeneratorExpression::Find(Destination) != std::string::npos) { + this->ActionsPerConfig = true; + } + + // We need per-config actions if any directories have generator expressions. + for (std::vector<std::string>::const_iterator i = dirs.begin(); + !this->ActionsPerConfig && i != dirs.end(); ++i) { + if (cmGeneratorExpression::Find(*i) != std::string::npos) { + this->ActionsPerConfig = true; + } + } +} + +cmInstallDirectoryGenerator::~cmInstallDirectoryGenerator() +{ +} + +void cmInstallDirectoryGenerator::Compute(cmLocalGenerator* lg) +{ + LocalGenerator = lg; +} + +void cmInstallDirectoryGenerator::GenerateScriptActions(std::ostream& os, + Indent const& indent) +{ + if (this->ActionsPerConfig) { + this->cmInstallGenerator::GenerateScriptActions(os, indent); + } else { + this->AddDirectoryInstallRule(os, "", indent, this->Directories); + } +} + +void cmInstallDirectoryGenerator::GenerateScriptForConfig( + std::ostream& os, const std::string& config, Indent const& indent) +{ + std::vector<std::string> dirs; + cmGeneratorExpression ge; + for (std::vector<std::string>::const_iterator i = this->Directories.begin(); + i != this->Directories.end(); ++i) { + CM_AUTO_PTR<cmCompiledGeneratorExpression> cge = ge.Parse(*i); + cmSystemTools::ExpandListArgument( + cge->Evaluate(this->LocalGenerator, config), dirs); + } + this->AddDirectoryInstallRule(os, config, indent, dirs); +} + +void cmInstallDirectoryGenerator::AddDirectoryInstallRule( + std::ostream& os, const std::string& config, Indent const& indent, + std::vector<std::string> const& dirs) +{ + // Write code to install the directories. + const char* no_rename = CM_NULLPTR; + this->AddInstallRule(os, this->GetDestination(config), + cmInstallType_DIRECTORY, dirs, this->Optional, + this->FilePermissions.c_str(), + this->DirPermissions.c_str(), no_rename, + this->LiteralArguments.c_str(), indent); +} + +std::string cmInstallDirectoryGenerator::GetDestination( + std::string const& config) const +{ + cmGeneratorExpression ge; + return ge.Parse(this->Destination)->Evaluate(this->LocalGenerator, config); +} |