cmFindPathCommand.cxx 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. /*=========================================================================
  2. Program: Insight Segmentation & Registration Toolkit
  3. Module: $RCSfile$
  4. Language: C++
  5. Date: $Date$
  6. Version: $Revision$
  7. Copyright (c) 2002 Insight Consortium. All rights reserved.
  8. See ITKCopyright.txt or http://www.itk.org/HTML/Copyright.htm 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 "cmFindPathCommand.h"
  14. #include "cmCacheManager.h"
  15. // cmFindPathCommand
  16. bool cmFindPathCommand::InitialPass(std::vector<std::string> const& argsIn)
  17. {
  18. if(argsIn.size() < 2)
  19. {
  20. this->SetError("called with incorrect number of arguments");
  21. return false;
  22. }
  23. // Now check and see if the value has been stored in the cache
  24. // already, if so use that value and don't look for the program
  25. std::string helpString = "What is the path where the file ";
  26. helpString += argsIn[1] + " can be found";
  27. std::vector<std::string> argst;
  28. size_t size = argsIn.size();
  29. for(unsigned int j = 0; j < size; ++j)
  30. {
  31. if(argsIn[j] != "DOC")
  32. {
  33. argst.push_back(argsIn[j]);
  34. }
  35. else
  36. {
  37. if(j+1 < size)
  38. {
  39. helpString = argsIn[j+1];
  40. }
  41. break;
  42. }
  43. }
  44. std::vector<std::string> args;
  45. cmSystemTools::ExpandListArguments(argst, args);
  46. const char* cacheValue
  47. = m_Makefile->GetDefinition(args[0].c_str());
  48. if(cacheValue && strcmp(cacheValue, "NOTFOUND"))
  49. {
  50. return true;
  51. }
  52. if(cacheValue)
  53. {
  54. cmCacheManager::CacheEntry* e =
  55. cmCacheManager::GetInstance()->GetCacheEntry(args[0].c_str());
  56. if(e)
  57. {
  58. helpString = e->m_HelpString;
  59. }
  60. }
  61. std::vector<std::string> path;
  62. // add any user specified paths
  63. for (unsigned int j = 2; j < args.size(); j++)
  64. {
  65. // expand variables
  66. std::string exp = args[j];
  67. cmSystemTools::ExpandRegistryValues(exp);
  68. // Glob the entry in case of wildcards.
  69. cmSystemTools::GlobDirs(exp.c_str(), path);
  70. }
  71. // add the standard path
  72. cmSystemTools::GetPath(path);
  73. unsigned int k;
  74. for(k=0; k < path.size(); k++)
  75. {
  76. std::string tryPath = path[k];
  77. tryPath += "/";
  78. tryPath += args[1];
  79. if(cmSystemTools::FileExists(tryPath.c_str()))
  80. {
  81. path[k] = cmSystemTools::CollapseFullPath(path[k].c_str());
  82. m_Makefile->AddCacheDefinition(args[0].c_str(),
  83. path[k].c_str(),
  84. helpString.c_str(),
  85. cmCacheManager::PATH);
  86. return true;
  87. }
  88. }
  89. m_Makefile->AddCacheDefinition(args[0].c_str(),
  90. "NOTFOUND",
  91. helpString.c_str(),
  92. cmCacheManager::PATH);
  93. return true;
  94. }