cmFindFileCommand.h 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  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. #ifndef cmFindFileCommand_h
  14. #define cmFindFileCommand_h
  15. #include "cmStandardIncludes.h"
  16. #include "cmCommand.h"
  17. /** \class cmFindFileCommand
  18. * \brief Define a command to search for an executable program.
  19. *
  20. * cmFindFileCommand is used to define a CMake variable
  21. * that specifies an executable program. The command searches
  22. * in the current path (e.g., PATH environment variable) for
  23. * an executable that matches one of the supplied names.
  24. */
  25. class cmFindFileCommand : public cmCommand
  26. {
  27. public:
  28. /**
  29. * This is a virtual constructor for the command.
  30. */
  31. virtual cmCommand* Clone()
  32. {
  33. return new cmFindFileCommand;
  34. }
  35. /**
  36. * This is called when the command is first encountered in
  37. * the CMakeLists.txt file.
  38. */
  39. virtual bool InitialPass(std::vector<std::string> const& args);
  40. /**
  41. * This determines if the command gets propagated down
  42. * to makefiles located in subdirectories.
  43. */
  44. virtual bool IsInherited() { return false; }
  45. /**
  46. * The name of the command as specified in CMakeList.txt.
  47. */
  48. virtual const char* GetName() { return "FIND_FILE";}
  49. /**
  50. * Succinct documentation.
  51. */
  52. virtual const char* GetTerseDocumentation()
  53. {
  54. return "Find a file.";
  55. }
  56. /**
  57. * More documentation.
  58. */
  59. virtual const char* GetFullDocumentation()
  60. {
  61. return
  62. "FIND_FILE(NAME file extrapath extrapath ... [DOC docstring])"
  63. "Find a file in the system PATH or in any extra paths specified in the command."
  64. "A cache entry called NAME is created to store the result. NOTFOUND is the value"
  65. " used if the file was not found. If DOC is specified the next argument is the "
  66. "documentation string for the cache entry NAME. Since Executables, "
  67. "can have different extensions on different platforms, FIND_PROGRAM,"
  68. " should be used instead of FIND_FILE when looking for and executable.";
  69. }
  70. cmTypeMacro(cmFindFileCommand, cmCommand);
  71. };
  72. #endif