cmInstallProgramsCommand.cxx 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133
  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. this->Destination = args[0];
  27. std::vector<std::string>::const_iterator s = args.begin();
  28. for (++s;s != args.end(); ++s)
  29. {
  30. this->FinalArgs.push_back(*s);
  31. }
  32. return true;
  33. }
  34. void cmInstallProgramsCommand::FinalPass()
  35. {
  36. bool files_mode = false;
  37. if(!this->FinalArgs.empty() && this->FinalArgs[0] == "FILES")
  38. {
  39. files_mode = true;
  40. }
  41. // two different options
  42. if (this->FinalArgs.size() > 1 || files_mode)
  43. {
  44. // for each argument, get the programs
  45. std::vector<std::string>::iterator s = this->FinalArgs.begin();
  46. if(files_mode)
  47. {
  48. // Skip the FILES argument in files mode.
  49. ++s;
  50. }
  51. for(;s != this->FinalArgs.end(); ++s)
  52. {
  53. // add to the result
  54. this->Files.push_back(this->FindInstallSource(s->c_str()));
  55. }
  56. }
  57. else // reg exp list
  58. {
  59. std::vector<std::string> programs;
  60. cmSystemTools::Glob(this->Makefile->GetCurrentDirectory(),
  61. this->FinalArgs[0].c_str(), programs);
  62. std::vector<std::string>::iterator s = programs.begin();
  63. // for each argument, get the programs
  64. for (;s != programs.end(); ++s)
  65. {
  66. this->Files.push_back(this->FindInstallSource(s->c_str()));
  67. }
  68. }
  69. // Use a file install generator.
  70. const char* no_permissions = "";
  71. const char* no_rename = "";
  72. const char* no_component = "";
  73. std::vector<std::string> no_configurations;
  74. this->Makefile->AddInstallGenerator(
  75. new cmInstallFilesGenerator(this->Files,
  76. this->Destination.c_str(), true,
  77. no_permissions, no_configurations,
  78. no_component, no_rename));
  79. }
  80. /**
  81. * Find a file in the build or source tree for installation given a
  82. * relative path from the CMakeLists.txt file. This will favor files
  83. * present in the build tree. If a full path is given, it is just
  84. * returned.
  85. */
  86. std::string cmInstallProgramsCommand
  87. ::FindInstallSource(const char* name) const
  88. {
  89. if(cmSystemTools::FileIsFullPath(name))
  90. {
  91. // This is a full path.
  92. return name;
  93. }
  94. // This is a relative path.
  95. std::string tb = this->Makefile->GetCurrentOutputDirectory();
  96. tb += "/";
  97. tb += name;
  98. std::string ts = this->Makefile->GetCurrentDirectory();
  99. ts += "/";
  100. ts += name;
  101. if(cmSystemTools::FileExists(tb.c_str()))
  102. {
  103. // The file exists in the binary tree. Use it.
  104. return tb;
  105. }
  106. else if(cmSystemTools::FileExists(ts.c_str()))
  107. {
  108. // The file exists in the source tree. Use it.
  109. return ts;
  110. }
  111. else
  112. {
  113. // The file doesn't exist. Assume it will be present in the
  114. // binary tree when the install occurs.
  115. return tb;
  116. }
  117. }