cmInstallProgramsCommand.cxx 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130
  1. /*=========================================================================
  2. Program: CMake - Cross-Platform Makefile Generator
  3. Module: $RCSfile$
  4. Language: C++
  5. Date: $Date$
  6. Version: $Revision$
  7. Copyright (c) 2002 Kitware, Inc., Insight Consortium. All rights reserved.
  8. See Copyright.txt or http://www.cmake.org/HTML/Copyright.html for details.
  9. This software is distributed WITHOUT ANY WARRANTY; without even
  10. the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
  11. PURPOSE. See the above copyright notices for more information.
  12. =========================================================================*/
  13. #include "cmInstallProgramsCommand.h"
  14. // cmExecutableCommand
  15. bool cmInstallProgramsCommand
  16. ::InitialPass(std::vector<std::string> const& args)
  17. {
  18. if(args.size() < 2)
  19. {
  20. this->SetError("called with incorrect number of arguments");
  21. return false;
  22. }
  23. // Enable the install target.
  24. this->Makefile->GetLocalGenerator()
  25. ->GetGlobalGenerator()->EnableInstallTarget();
  26. // Create an INSTALL_PROGRAMS target specifically for this path.
  27. this->TargetName = "INSTALL_PROGRAMS_"+args[0];
  28. cmTarget& target = this->Makefile->GetTargets()[this->TargetName];
  29. target.SetInAll(false);
  30. target.SetType(cmTarget::INSTALL_PROGRAMS, this->TargetName.c_str());
  31. target.SetInstallPath(args[0].c_str());
  32. std::vector<std::string>::const_iterator s = args.begin();
  33. for (++s;s != args.end(); ++s)
  34. {
  35. this->FinalArgs.push_back(*s);
  36. }
  37. return true;
  38. }
  39. void cmInstallProgramsCommand::FinalPass()
  40. {
  41. std::vector<std::string>& targetSourceLists =
  42. this->Makefile->GetTargets()[this->TargetName].GetSourceLists();
  43. bool files_mode = false;
  44. if(!this->FinalArgs.empty() && this->FinalArgs[0] == "FILES")
  45. {
  46. files_mode = true;
  47. }
  48. // two different options
  49. if (this->FinalArgs.size() > 1 || files_mode)
  50. {
  51. // for each argument, get the programs
  52. std::vector<std::string>::iterator s = this->FinalArgs.begin();
  53. if(files_mode)
  54. {
  55. // Skip the FILES argument in files mode.
  56. ++s;
  57. }
  58. for(;s != this->FinalArgs.end(); ++s)
  59. {
  60. // add to the result
  61. targetSourceLists.push_back(this->FindInstallSource(s->c_str()));
  62. }
  63. }
  64. else // reg exp list
  65. {
  66. std::vector<std::string> programs;
  67. cmSystemTools::Glob(this->Makefile->GetCurrentDirectory(),
  68. this->FinalArgs[0].c_str(), programs);
  69. std::vector<std::string>::iterator s = programs.begin();
  70. // for each argument, get the programs
  71. for (;s != programs.end(); ++s)
  72. {
  73. targetSourceLists.push_back(this->FindInstallSource(s->c_str()));
  74. }
  75. }
  76. }
  77. /**
  78. * Find a file in the build or source tree for installation given a
  79. * relative path from the CMakeLists.txt file. This will favor files
  80. * present in the build tree. If a full path is given, it is just
  81. * returned.
  82. */
  83. std::string cmInstallProgramsCommand
  84. ::FindInstallSource(const char* name) const
  85. {
  86. if(cmSystemTools::FileIsFullPath(name))
  87. {
  88. // This is a full path.
  89. return name;
  90. }
  91. // This is a relative path.
  92. std::string tb = this->Makefile->GetCurrentOutputDirectory();
  93. tb += "/";
  94. tb += name;
  95. std::string ts = this->Makefile->GetCurrentDirectory();
  96. ts += "/";
  97. ts += name;
  98. if(cmSystemTools::FileExists(tb.c_str()))
  99. {
  100. // The file exists in the binary tree. Use it.
  101. return tb;
  102. }
  103. else if(cmSystemTools::FileExists(ts.c_str()))
  104. {
  105. // The file exists in the source tree. Use it.
  106. return ts;
  107. }
  108. else
  109. {
  110. // The file doesn't exist. Assume it will be present in the
  111. // binary tree when the install occurs.
  112. return tb;
  113. }
  114. }