/* 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 #include #include #include class cmMakefile; /** \class cmVariableWatch * \brief Helper class for watching of variable accesses. * * Calls function when variable is accessed */ class cmVariableWatch { public: using WatchMethod = void (*)(const std::string&, int, void*, const char*, const cmMakefile*); using DeleteData = void (*)(void*); cmVariableWatch(); ~cmVariableWatch(); /** * Add watch to the variable */ bool AddWatch(const std::string& variable, WatchMethod method, void* client_data = nullptr, DeleteData delete_data = nullptr); void RemoveWatch(const std::string& variable, WatchMethod method, void* client_data = nullptr); /** * This method is called when variable is accessed */ bool VariableAccessed(const std::string& variable, int access_type, const char* newValue, const cmMakefile* mf) const; /** * Different access types. */ enum { VARIABLE_READ_ACCESS, UNKNOWN_VARIABLE_READ_ACCESS, UNKNOWN_VARIABLE_DEFINED_ACCESS, VARIABLE_MODIFIED_ACCESS, VARIABLE_REMOVED_ACCESS, NO_ACCESS }; /** * Return the access as string */ static const std::string& GetAccessAsString(int access_type); protected: struct Pair { WatchMethod Method = nullptr; void* ClientData = nullptr; DeleteData DeleteDataCall = nullptr; ~Pair() { if (this->DeleteDataCall && this->ClientData) { this->DeleteDataCall(this->ClientData); } } Pair() = default; Pair(const Pair&) = delete; Pair& operator=(const Pair&) = delete; }; using VectorOfPairs = std::vector>; using StringToVectorOfPairs = std::map; StringToVectorOfPairs WatchMap; };