cmFileTimeComparison.h 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  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. cmFileTimeComparison(const cmFileTimeComparison&) = delete;
  19. cmFileTimeComparison& operator=(const cmFileTimeComparison&) = delete;
  20. /**
  21. * Compare file modification times.
  22. * Return true for successful comparison and false for error.
  23. * When true is returned, result has -1, 0, +1 for
  24. * f1 older, same, or newer than f2.
  25. */
  26. bool FileTimeCompare(const std::string& f1, const std::string& f2,
  27. int* result);
  28. /**
  29. * Compare file modification times. Return true unless both files
  30. * exist and have modification times less than 1 second apart.
  31. */
  32. bool FileTimesDiffer(const std::string& f1, const std::string& f2);
  33. protected:
  34. cmFileTimeComparisonInternal* Internals;
  35. };
  36. #endif