/*============================================================================ 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 const& dirs, const char* dest, const char* file_permissions, const char* dir_permissions, std::vector 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(0), 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::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 dirs; cmGeneratorExpression ge; for(std::vector::const_iterator i = this->Directories.begin(); i != this->Directories.end(); ++i) { cmsys::auto_ptr 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 const& dirs) { // Write code to install the directories. const char* no_rename = 0; 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); }