/*============================================================================ 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 "cmInstallCommandArguments.h" #include "cmSystemTools.h" // Table of valid permissions. const char* cmInstallCommandArguments::PermissionsTable[] = { "OWNER_READ", "OWNER_WRITE", "OWNER_EXECUTE", "GROUP_READ", "GROUP_WRITE", "GROUP_EXECUTE", "WORLD_READ", "WORLD_WRITE", "WORLD_EXECUTE", "SETUID", "SETGID", 0 }; const std::string cmInstallCommandArguments::EmptyString; cmInstallCommandArguments::cmInstallCommandArguments( const std::string& defaultComponent) :Parser() ,ArgumentGroup() ,Destination (&Parser, "DESTINATION" , &ArgumentGroup) ,Component (&Parser, "COMPONENT" , &ArgumentGroup) ,Rename (&Parser, "RENAME" , &ArgumentGroup) ,Permissions (&Parser, "PERMISSIONS" , &ArgumentGroup) ,Configurations(&Parser, "CONFIGURATIONS", &ArgumentGroup) ,Optional (&Parser, "OPTIONAL" , &ArgumentGroup) ,NamelinkOnly (&Parser, "NAMELINK_ONLY" , &ArgumentGroup) ,NamelinkSkip (&Parser, "NAMELINK_SKIP" , &ArgumentGroup) ,GenericArguments(0) ,DefaultComponentName(defaultComponent) { } const std::string& cmInstallCommandArguments::GetDestination() const { if (!this->DestinationString.empty()) { return this->DestinationString; } if (this->GenericArguments!=0) { return this->GenericArguments->GetDestination(); } return this->EmptyString; } const std::string& cmInstallCommandArguments::GetComponent() const { if (!this->Component.GetString().empty()) { return this->Component.GetString(); } if (this->GenericArguments!=0) { return this->GenericArguments->GetComponent(); } if (!this->DefaultComponentName.empty()) { return this->DefaultComponentName; } static std::string unspecifiedComponent = "Unspecified"; return unspecifiedComponent; } const std::string& cmInstallCommandArguments::GetRename() const { if (!this->Rename.GetString().empty()) { return this->Rename.GetString(); } if (this->GenericArguments!=0) { return this->GenericArguments->GetRename(); } return this->EmptyString; } const std::string& cmInstallCommandArguments::GetPermissions() const { if (!this->PermissionsString.empty()) { return this->PermissionsString; } if (this->GenericArguments!=0) { return this->GenericArguments->GetPermissions(); } return this->EmptyString; } bool cmInstallCommandArguments::GetOptional() const { if (this->Optional.IsEnabled()) { return true; } if (this->GenericArguments!=0) { return this->GenericArguments->GetOptional(); } return false; } bool cmInstallCommandArguments::GetNamelinkOnly() const { if (this->NamelinkOnly.IsEnabled()) { return true; } if (this->GenericArguments!=0) { return this->GenericArguments->GetNamelinkOnly(); } return false; } bool cmInstallCommandArguments::GetNamelinkSkip() const { if (this->NamelinkSkip.IsEnabled()) { return true; } if (this->GenericArguments!=0) { return this->GenericArguments->GetNamelinkSkip(); } return false; } const std::vector& cmInstallCommandArguments::GetConfigurations() const { if (!this->Configurations.GetVector().empty()) { return this->Configurations.GetVector(); } if (this->GenericArguments!=0) { return this->GenericArguments->GetConfigurations(); } return this->Configurations.GetVector(); } bool cmInstallCommandArguments::Finalize() { if (!this->CheckPermissions()) { return false; } this->DestinationString = this->Destination.GetString(); cmSystemTools::ConvertToUnixSlashes(this->DestinationString); return true; } void cmInstallCommandArguments::Parse(const std::vector* args, std::vector* unconsumedArgs) { this->Parser.Parse(args, unconsumedArgs); } bool cmInstallCommandArguments::CheckPermissions() { this->PermissionsString = ""; for(std::vector::const_iterator permIt = this->Permissions.GetVector().begin(); permIt != this->Permissions.GetVector().end(); ++permIt) { if (!this->CheckPermissions(*permIt, this->PermissionsString)) { return false; } } return true; } bool cmInstallCommandArguments::CheckPermissions( const std::string& onePermission, std::string& permissions) { // Check the permission against the table. for(const char** valid = cmInstallCommandArguments::PermissionsTable; *valid; ++valid) { if(onePermission == *valid) { // This is a valid permission. permissions += " "; permissions += onePermission; return true; } } // This is not a valid permission. return false; } cmInstallCommandIncludesArgument::cmInstallCommandIncludesArgument() { } const std::vector& cmInstallCommandIncludesArgument::GetIncludeDirs() const { return this->IncludeDirs; } void cmInstallCommandIncludesArgument::Parse( const std::vector* args, std::vector*) { if(args->empty()) { return; } std::vector::const_iterator it = args->begin(); ++it; for ( ; it != args->end(); ++it) { std::string dir = *it; if (!cmSystemTools::FileIsFullPath(it->c_str()) && cmGeneratorExpression::Find(*it) == std::string::npos) { dir = "$/" + dir; } cmSystemTools::ConvertToUnixSlashes(dir); this->IncludeDirs.push_back(dir); } }