diff options
Diffstat (limited to 'Source/cmInstallProgramsCommand.cxx')
-rw-r--r-- | Source/cmInstallProgramsCommand.cxx | 124 |
1 files changed, 124 insertions, 0 deletions
diff --git a/Source/cmInstallProgramsCommand.cxx b/Source/cmInstallProgramsCommand.cxx new file mode 100644 index 0000000..2e5fc1f --- /dev/null +++ b/Source/cmInstallProgramsCommand.cxx @@ -0,0 +1,124 @@ +/*============================================================================ + 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 "cmInstallProgramsCommand.h" + +#include "cmInstallFilesGenerator.h" +// cmExecutableCommand +bool cmInstallProgramsCommand::InitialPass( + std::vector<std::string> const& args, cmExecutionStatus&) +{ + if (args.size() < 2) { + this->SetError("called with incorrect number of arguments"); + return false; + } + + // Enable the install target. + this->Makefile->GetGlobalGenerator()->EnableInstallTarget(); + + this->Destination = args[0]; + + this->FinalArgs.insert(this->FinalArgs.end(), args.begin() + 1, args.end()); + + this->Makefile->GetGlobalGenerator()->AddInstallComponent( + this->Makefile->GetSafeDefinition("CMAKE_INSTALL_DEFAULT_COMPONENT_NAME")); + + return true; +} + +void cmInstallProgramsCommand::FinalPass() +{ + bool files_mode = false; + if (!this->FinalArgs.empty() && this->FinalArgs[0] == "FILES") { + files_mode = true; + } + + // two different options + if (this->FinalArgs.size() > 1 || files_mode) { + // for each argument, get the programs + std::vector<std::string>::iterator s = this->FinalArgs.begin(); + if (files_mode) { + // Skip the FILES argument in files mode. + ++s; + } + for (; s != this->FinalArgs.end(); ++s) { + // add to the result + this->Files.push_back(this->FindInstallSource(s->c_str())); + } + } else // reg exp list + { + std::vector<std::string> programs; + cmSystemTools::Glob(this->Makefile->GetCurrentSourceDirectory(), + this->FinalArgs[0], programs); + + std::vector<std::string>::iterator s = programs.begin(); + // for each argument, get the programs + for (; s != programs.end(); ++s) { + this->Files.push_back(this->FindInstallSource(s->c_str())); + } + } + + // Construct the destination. This command always installs under + // the prefix. We skip the leading slash given by the user. + std::string destination = this->Destination.substr(1); + cmSystemTools::ConvertToUnixSlashes(destination); + if (destination.empty()) { + destination = "."; + } + + // Use a file install generator. + const char* no_permissions = ""; + const char* no_rename = ""; + bool no_exclude_from_all = false; + std::string no_component = + this->Makefile->GetSafeDefinition("CMAKE_INSTALL_DEFAULT_COMPONENT_NAME"); + std::vector<std::string> no_configurations; + cmInstallGenerator::MessageLevel message = + cmInstallGenerator::SelectMessageLevel(this->Makefile); + this->Makefile->AddInstallGenerator(new cmInstallFilesGenerator( + this->Files, destination.c_str(), true, no_permissions, no_configurations, + no_component.c_str(), message, no_exclude_from_all, no_rename)); +} + +/** + * Find a file in the build or source tree for installation given a + * relative path from the CMakeLists.txt file. This will favor files + * present in the build tree. If a full path is given, it is just + * returned. + */ +std::string cmInstallProgramsCommand::FindInstallSource(const char* name) const +{ + if (cmSystemTools::FileIsFullPath(name) || + cmGeneratorExpression::Find(name) == 0) { + // This is a full path. + return name; + } + + // This is a relative path. + std::string tb = this->Makefile->GetCurrentBinaryDirectory(); + tb += "/"; + tb += name; + std::string ts = this->Makefile->GetCurrentSourceDirectory(); + ts += "/"; + ts += name; + + if (cmSystemTools::FileExists(tb.c_str())) { + // The file exists in the binary tree. Use it. + return tb; + } else if (cmSystemTools::FileExists(ts.c_str())) { + // The file exists in the source tree. Use it. + return ts; + } else { + // The file doesn't exist. Assume it will be present in the + // binary tree when the install occurs. + return tb; + } +} |