| /* Distributed under the OSI-approved BSD 3-Clause License.  See accompanying | 
 |    file Copyright.txt or https://cmake.org/licensing for details.  */ | 
 | #pragma once | 
 |  | 
 | #include "cmConfigure.h" // IWYU pragma: keep | 
 |  | 
 | #include <string> | 
 | #include <unordered_map> | 
 |  | 
 | #include "cmFileTime.h" // IWYU pragma: keep | 
 |  | 
 | /** \class cmFileTimeCache | 
 |  * \brief Caches file modification times in an internal map for fast lookups. | 
 |  */ | 
 | class cmFileTimeCache | 
 | { | 
 | public: | 
 |   cmFileTimeCache(); | 
 |   ~cmFileTimeCache(); | 
 |  | 
 |   cmFileTimeCache(const cmFileTimeCache&) = delete; | 
 |   cmFileTimeCache& operator=(const cmFileTimeCache&) = delete; | 
 |  | 
 |   /** | 
 |    * @brief Loads the file time from the cache or the file system. | 
 |    * @return true on success | 
 |    */ | 
 |   bool Load(std::string const& fileName, cmFileTime& fileTime); | 
 |  | 
 |   /** | 
 |    * @brief Removes a file time from the cache | 
 |    * @return true if the file was found in the cache and removed | 
 |    */ | 
 |   bool Remove(std::string const& fileName); | 
 |  | 
 |   /** | 
 |    * @brief Compare file modification times. | 
 |    * @return true for successful comparison and false for error. | 
 |    * | 
 |    * When true is returned, result has -1, 0, +1 for | 
 |    * f1 older, same, or newer than f2. | 
 |    */ | 
 |   bool Compare(std::string const& f1, std::string const& f2, int* result); | 
 |  | 
 |   /** | 
 |    * @brief Compare file modification times. | 
 |    * @return true unless both files exist and have modification times less | 
 |    *         than 1 second apart. | 
 |    */ | 
 |   bool DifferS(std::string const& f1, std::string const& f2); | 
 |  | 
 | private: | 
 |   std::unordered_map<std::string, cmFileTime> Cache; | 
 | }; |