summaryrefslogtreecommitdiffstats
path: root/Source/cmVariableWatch.h
blob: fc24d179c037b8c74989f172b82f4d45bd397c30 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
/*=========================================================================

  Program:   CMake - Cross-Platform Makefile Generator
  Module:    $RCSfile$
  Language:  C++
  Date:      $Date$
  Version:   $Revision$

  Copyright (c) 2002 Kitware, Inc., Insight Consortium.  All rights reserved.
  See Copyright.txt or http://www.cmake.org/HTML/Copyright.html for details.

     This software is distributed WITHOUT ANY WARRANTY; without even 
     the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR 
     PURPOSE.  See the above copyright notices for more information.

=========================================================================*/
#ifndef cmVariableWatch_h
#define cmVariableWatch_h

#include "cmStandardIncludes.h"

class cmMakefile;

/** \class cmVariableWatch
 * \brief Helper class for watching of variable accesses.
 *
 * Calls function when variable is accessed
 */
class cmVariableWatch
{
public:
  typedef void (*WatchMethod)(const std::string& variable, int access_type,
    void* client_data, const char* newValue, const cmMakefile* mf);

  cmVariableWatch();
  ~cmVariableWatch();

  /**
   * Add watch to the variable
   */
  void AddWatch(const std::string& variable, WatchMethod method,
                void* client_data=0);
  void RemoveWatch(const std::string& variable, WatchMethod method);
  
  /**
   * This method is called when variable is accessed
   */
  void VariableAccessed(const std::string& variable, int access_type,
    const char* newValue, const cmMakefile* mf) const;

  /**
   * Different access types.
   */
  enum
    {
    VARIABLE_READ_ACCESS = 0,
    UNKNOWN_VARIABLE_READ_ACCESS,
    UNKNOWN_VARIABLE_DEFINED_ACCESS,
    ALLOWED_UNKNOWN_VARIABLE_READ_ACCESS,
    VARIABLE_MODIFIED_ACCESS,
    VARIABLE_REMOVED_ACCESS,
    NO_ACCESS
    };

  /**
   * Return the access as string
   */
  static const char* GetAccessAsString(int access_type);
  
protected:
  struct Pair
  {
    WatchMethod Method;
    void*        ClientData;
    Pair() : Method(0), ClientData(0) {}
  };

  typedef std::vector< Pair > VectorOfPairs;
  typedef std::map<cmStdString, VectorOfPairs > StringToVectorOfPairs;

  StringToVectorOfPairs WatchMap;
};


#endif
='commitgraph'> * Issue #6716/3: Exclude 2to3 tests from compileall.Martin v. Löwis2010-03-161-1/+1 * Add UUID for 3.2 DLL.Martin v. Löwis2010-03-161-0/+1 * Merged revisions 78976 via svnmerge fromMartin v. Löwis2010-03-161-1/+1 * Merged revisions 78838-78839,78917,78919,78934,78937 via svnmerge fromFlorent Xicluna2010-03-131-2/+3 * Merged revisions 78939 via svnmerge fromAntoine Pitrou2010-03-131-3/+150 * Merged revisions 78932 via svnmerge fromMartin v. Löwis2010-03-131-0/+8 * convert shebang lines: python -> python3Benjamin Peterson2010-03-1166-66/+66 * Merged revisions 78806 via svnmerge fromBenjamin Peterson2010-03-082-145/+145 * Merged revisions 78416,78430 via svnmerge fromR. David Murray2010-03-082-0/+32 * Merged revisions 77599-77601 via svnmerge fromAntoine Pitrou2010-01-182-0/+1001 * Merged revisions 77226 via svnmerge fromMartin v. Löwis2010-01-021-3/+3 * Merged revisions 76990-76991 via svnmerge fromMartin v. Löwis2009-12-221-2/+2 * Merged revisions 76692 via svnmerge fromMartin v. Löwis2009-12-061-17/+9 * Merged revisions 75264,75268,75293,75318,75391-75392,75436,75478,75971,76003,...Benjamin Peterson2009-11-251-1/+1 * convert to use print() functionBenjamin Peterson2009-11-091-6/+6 * fix some importsBenjamin Peterson2009-11-093-5/+5 * Remove AtheOS support, as per PEP 11 (which claims that all code was removed ...Antoine Pitrou2009-10-241-7/+1 * Merged revisions 75396 via svnmerge fromAmaury Forgeot d'Arc2009-10-131-0/+5 * Merged revisions 75370-75372 via svnmerge fromGeorg Brandl2009-10-112-5/+124 * Merged revisions 75272-75273 via svnmerge fromAmaury Forgeot d'Arc2009-10-061-7/+121 * Merged revisions 74865,75175,75180 via svnmerge fromBenjamin Peterson2009-10-04