2009-09-28 15:43:28 +00:00
|
|
|
/*============================================================================
|
|
|
|
CMake - Cross Platform Makefile Generator
|
|
|
|
Copyright 2000-2009 Kitware, Inc., Insight Software Consortium
|
2003-01-08 17:59:52 +00:00
|
|
|
|
2009-09-28 15:43:28 +00:00
|
|
|
Distributed under the OSI-approved BSD License (the "License");
|
|
|
|
see accompanying file Copyright.txt for details.
|
2003-01-08 17:59:52 +00:00
|
|
|
|
2009-09-28 15:43:28 +00:00
|
|
|
This software is distributed WITHOUT ANY WARRANTY; without even the
|
|
|
|
implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
|
|
See the License for more information.
|
|
|
|
============================================================================*/
|
2003-01-08 17:59:52 +00:00
|
|
|
#ifndef cmVariableWatch_h
|
|
|
|
#define cmVariableWatch_h
|
|
|
|
|
|
|
|
#include "cmStandardIncludes.h"
|
|
|
|
|
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,
|
2007-04-11 19:13:05 +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,
|
2013-08-02 19:44:15 +00:00
|
|
|
void* client_data=0, DeleteData delete_data=0);
|
2013-08-06 18:12:54 +00:00
|
|
|
void RemoveWatch(const std::string& variable, WatchMethod method,
|
|
|
|
void* client_data=0);
|
2012-08-13 17:42:58 +00:00
|
|
|
|
2003-01-08 17:59:52 +00:00
|
|
|
/**
|
|
|
|
* This method is called when variable is accessed
|
|
|
|
*/
|
2007-04-11 19:13:05 +00:00
|
|
|
void VariableAccessed(const std::string& variable, int access_type,
|
|
|
|
const char* newValue, const cmMakefile* mf) const;
|
2003-01-08 17:59:52 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Different access types.
|
|
|
|
*/
|
|
|
|
enum
|
|
|
|
{
|
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
|
|
|
ALLOWED_UNKNOWN_VARIABLE_READ_ACCESS,
|
|
|
|
VARIABLE_MODIFIED_ACCESS,
|
|
|
|
VARIABLE_REMOVED_ACCESS,
|
|
|
|
NO_ACCESS
|
2003-01-08 17:59:52 +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;
|
|
|
|
void* ClientData;
|
2013-08-02 19:44:15 +00:00
|
|
|
DeleteData DeleteDataCall;
|
|
|
|
Pair() : Method(0), ClientData(0), DeleteDataCall(0) {}
|
|
|
|
~Pair()
|
|
|
|
{
|
|
|
|
if (this->DeleteDataCall && this->ClientData)
|
|
|
|
{
|
|
|
|
this->DeleteDataCall(this->ClientData);
|
|
|
|
}
|
|
|
|
}
|
2003-01-08 17:59:52 +00:00
|
|
|
};
|
|
|
|
|
2013-08-02 19:43:15 +00:00
|
|
|
typedef std::vector< Pair* > VectorOfPairs;
|
2003-01-09 16:27:57 +00:00
|
|
|
typedef std::map<cmStdString, 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
|