2016-09-27 19:01:08 +00:00
|
|
|
/* Distributed under the OSI-approved BSD 3-Clause License. See accompanying
|
|
|
|
file Copyright.txt or https://cmake.org/licensing for details. */
|
2003-01-08 17:59:52 +00:00
|
|
|
#ifndef cmVariableWatch_h
|
|
|
|
#define cmVariableWatch_h
|
|
|
|
|
2016-08-16 23:08:13 +00:00
|
|
|
#include <cmConfigure.h> // IWYU pragma: keep
|
|
|
|
|
|
|
|
#include <map>
|
|
|
|
#include <string>
|
|
|
|
#include <vector>
|
2003-01-08 17:59:52 +00:00
|
|
|
|
2007-04-11 19:13:05 +00:00
|
|
|
class cmMakefile;
|
|
|
|
|
2003-01-08 17:59:52 +00:00
|
|
|
/** \class cmVariableWatch
|
|
|
|
* \brief Helper class for watching of variable accesses.
|
|
|
|
*
|
|
|
|
* Calls function when variable is accessed
|
|
|
|
*/
|
|
|
|
class cmVariableWatch
|
|
|
|
{
|
|
|
|
public:
|
2006-03-10 16:13:15 +00:00
|
|
|
typedef void (*WatchMethod)(const std::string& variable, int access_type,
|
2016-05-16 14:34:04 +00:00
|
|
|
void* client_data, const char* newValue,
|
|
|
|
const cmMakefile* mf);
|
2013-08-02 19:44:15 +00:00
|
|
|
typedef void (*DeleteData)(void* client_data);
|
2003-01-08 17:59:52 +00:00
|
|
|
|
|
|
|
cmVariableWatch();
|
|
|
|
~cmVariableWatch();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add watch to the variable
|
|
|
|
*/
|
2013-08-06 18:08:57 +00:00
|
|
|
bool AddWatch(const std::string& variable, WatchMethod method,
|
2016-06-27 20:44:16 +00:00
|
|
|
void* client_data = CM_NULLPTR,
|
|
|
|
DeleteData delete_data = CM_NULLPTR);
|
2013-08-06 18:12:54 +00:00
|
|
|
void RemoveWatch(const std::string& variable, WatchMethod method,
|
2016-06-27 20:44:16 +00:00
|
|
|
void* client_data = CM_NULLPTR);
|
2012-08-13 17:42:58 +00:00
|
|
|
|
2003-01-08 17:59:52 +00:00
|
|
|
/**
|
|
|
|
* This method is called when variable is accessed
|
|
|
|
*/
|
2016-03-23 09:37:51 +00:00
|
|
|
bool VariableAccessed(const std::string& variable, int access_type,
|
2016-05-16 14:34:04 +00:00
|
|
|
const char* newValue, const cmMakefile* mf) const;
|
2003-01-08 17:59:52 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Different access types.
|
|
|
|
*/
|
|
|
|
enum
|
2016-05-16 14:34:04 +00:00
|
|
|
{
|
2007-04-11 19:13:05 +00:00
|
|
|
VARIABLE_READ_ACCESS = 0,
|
|
|
|
UNKNOWN_VARIABLE_READ_ACCESS,
|
2007-05-17 21:40:59 +00:00
|
|
|
UNKNOWN_VARIABLE_DEFINED_ACCESS,
|
2007-04-11 19:13:05 +00:00
|
|
|
VARIABLE_MODIFIED_ACCESS,
|
|
|
|
VARIABLE_REMOVED_ACCESS,
|
|
|
|
NO_ACCESS
|
2016-05-16 14:34:04 +00:00
|
|
|
};
|
2007-04-11 19:13:05 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Return the access as string
|
|
|
|
*/
|
|
|
|
static const char* GetAccessAsString(int access_type);
|
2012-08-13 17:42:58 +00:00
|
|
|
|
2003-01-08 17:59:52 +00:00
|
|
|
protected:
|
|
|
|
struct Pair
|
|
|
|
{
|
2006-03-15 16:02:08 +00:00
|
|
|
WatchMethod Method;
|
2016-05-16 14:34:04 +00:00
|
|
|
void* ClientData;
|
|
|
|
DeleteData DeleteDataCall;
|
|
|
|
Pair()
|
2016-06-27 20:44:16 +00:00
|
|
|
: Method(CM_NULLPTR)
|
|
|
|
, ClientData(CM_NULLPTR)
|
|
|
|
, DeleteDataCall(CM_NULLPTR)
|
2016-05-16 14:34:04 +00:00
|
|
|
{
|
|
|
|
}
|
2013-08-02 19:44:15 +00:00
|
|
|
~Pair()
|
2016-05-16 14:34:04 +00:00
|
|
|
{
|
|
|
|
if (this->DeleteDataCall && this->ClientData) {
|
2013-08-02 19:44:15 +00:00
|
|
|
this->DeleteDataCall(this->ClientData);
|
|
|
|
}
|
2016-05-16 14:34:04 +00:00
|
|
|
}
|
2003-01-08 17:59:52 +00:00
|
|
|
};
|
|
|
|
|
2016-05-16 14:34:04 +00:00
|
|
|
typedef std::vector<Pair*> VectorOfPairs;
|
|
|
|
typedef std::map<std::string, VectorOfPairs> StringToVectorOfPairs;
|
2003-01-08 17:59:52 +00:00
|
|
|
|
2006-03-15 16:02:08 +00:00
|
|
|
StringToVectorOfPairs WatchMap;
|
2003-01-08 17:59:52 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|