blob: e03156e8a8ea6c6208c6acfac92860ce0148f65c (
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
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
|
/********************* */
/** cdo.h
** Original author: mdeters
** Major contributors: none
** Minor contributors (to current version): barrett
** This file is part of the CVC4 prototype.
** Copyright (c) 2009, 2010 The Analysis of Computer Systems Group (ACSys)
** Courant Institute of Mathematical Sciences
** New York University
** See the file COPYING in the top-level source directory for licensing
** information.
**
** A context-dependent object.
**/
#include "cvc4_private.h"
#ifndef __CVC4__CONTEXT__CDO_H
#define __CVC4__CONTEXT__CDO_H
#include "context/context.h"
#include "util/Assert.h"
namespace CVC4 {
namespace context {
/**
* Most basic template for context-dependent objects. Simply makes a copy
* (using the copy constructor) of class T when saving, and copies it back
* (using operator=) during restore.
*/
template <class T>
class CDO : public ContextObj {
/**
* The data of type T being stored in this context-dependent object.
*/
T d_data;
/**
* Implementation of mandatory ContextObj method save: simply copies the
* current data to a copy using the copy constructor. Memory is allocated
* using the ContextMemoryManager.
*/
virtual ContextObj* save(ContextMemoryManager* pCMM) {
return new(pCMM) CDO<T>(*this);
}
/**
* Implementation of mandatory ContextObj method restore: simply copies the
* saved data back from the saved copy using operator= for T.
*/
virtual void restore(ContextObj* pContextObj) {
d_data = ((CDO<T>*) pContextObj)->d_data;
}
/**
* Copy constructor - it's private to ensure it is only used by save().
* Basic CDO objects, cannot be copied-they have to be unique.
*/
CDO(const CDO<T>& cdo) : ContextObj(cdo), d_data(cdo.d_data) {}
/**
* operator= for CDO is private to ensure CDO object is not copied.
*/
CDO<T>& operator=(const CDO<T>& cdo);
public:
/**
* Main constructor - uses default constructor for T to create the initial
* value of d_data.
*/
CDO(Context* context) : ContextObj(context) {}
/**
* Constructor from object of type T. Creates a ContextObj and sets the data
* to the given data value. Note that this value is only valid in the
* current Scope. If the Scope is popped, the value will revert to whatever
* is assigned by the default constructor for T
*/
CDO(Context* context, const T& data) : ContextObj(context) {
makeCurrent();
d_data = data;
}
/**
* Destructor - call destroy() method
*/
~CDO() throw() { destroy(); }
/**
* Set the data in the CDO. First call makeCurrent.
*/
void set(const T& data) {
makeCurrent();
d_data = data;
}
/**
* Get the current data from the CDO. Read-only.
*/
const T& get() const { return d_data; }
/**
* For convenience, define operator T to be the same as get().
*/
operator T() { return get(); }
/**
* For convenience, define operator= that takes an object of type T.
*/
CDO<T>& operator=(const T& data) {
set(data);
return *this;
}
};/* class CDO */
}/* CVC4::context namespace */
}/* CVC4 namespace */
#endif /* __CVC4__CONTEXT__CDO_H */
|