cmFileTimeComparison.h 1.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. /* Distributed under the OSI-approved BSD 3-Clause License. See accompanying
  2. file Copyright.txt or https://cmake.org/licensing for details. */
  3. #ifndef cmFileTimeComparison_h
  4. #define cmFileTimeComparison_h
  5. #include "cmConfigure.h" // IWYU pragma: keep
  6. #include <string>
  7. class cmFileTimeComparisonInternal;
  8. /** \class cmFileTimeComparison
  9. * \brief Helper class for comparing file modification times.
  10. *
  11. * Compare file modification times or test if file modification times differ.
  12. */
  13. class cmFileTimeComparison
  14. {
  15. public:
  16. cmFileTimeComparison();
  17. ~cmFileTimeComparison();
  18. /**
  19. * Compare file modification times.
  20. * Return true for successful comparison and false for error.
  21. * When true is returned, result has -1, 0, +1 for
  22. * f1 older, same, or newer than f2.
  23. */
  24. bool FileTimeCompare(const std::string& f1, const std::string& f2,
  25. int* result);
  26. /**
  27. * Compare file modification times. Return true unless both files
  28. * exist and have modification times less than 1 second apart.
  29. */
  30. bool FileTimesDiffer(const std::string& f1, const std::string& f2);
  31. protected:
  32. cmFileTimeComparisonInternal* Internals;
  33. };
  34. #endif