summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDejan Jovanović <dejan@cs.nyu.edu>2012-12-21 19:14:45 -0500
committerDejan Jovanović <dejan@cs.nyu.edu>2012-12-21 19:14:45 -0500
commit7ce4d047670810a10a3f0fc202cd7d94bb4b7e69 (patch)
treead7eb957617e6f94e5358136ee7095cbeb4e13bd
parentb53db2d3718368d25dec563ecf33a909ad8548f7 (diff)
parentd1cd7732b17b280ad17d12a84399ff05cd1d77c4 (diff)
Merge branch '1.0.x'
-rw-r--r--src/theory/datatypes/type_enumerator.h20
1 files changed, 20 insertions, 0 deletions
diff --git a/src/theory/datatypes/type_enumerator.h b/src/theory/datatypes/type_enumerator.h
index d8557fcaf..2a14d7fba 100644
--- a/src/theory/datatypes/type_enumerator.h
+++ b/src/theory/datatypes/type_enumerator.h
@@ -57,6 +57,7 @@ class DatatypesEnumerator : public TypeEnumeratorBase<DatatypesEnumerator> {
}
}
+
public:
DatatypesEnumerator(TypeNode type) throw() :
@@ -91,6 +92,25 @@ public:
newEnumerators();
}
+ DatatypesEnumerator(const DatatypesEnumerator& other) :
+ TypeEnumeratorBase<DatatypesEnumerator>(other.getType()),
+ d_datatype(other.d_datatype),
+ d_ctor(other.d_ctor),
+ d_zeroCtor(other.d_zeroCtor),
+ d_argEnumerators(NULL) {
+
+ if (other.d_argEnumerators != NULL) {
+ d_argEnumerators = new TypeEnumerator*[d_datatype[d_ctor].getNumArgs()];
+ for(size_t a = 0; a < d_datatype[d_ctor].getNumArgs(); ++a) {
+ if (other.d_argEnumerators[a] != NULL) {
+ d_argEnumerators[a] = new TypeEnumerator(*other.d_argEnumerators[a]);
+ } else {
+ d_argEnumerators[a] = NULL;
+ }
+ }
+ }
+ }
+
~DatatypesEnumerator() throw() {
deleteEnumerators();
}
generated by cgit on debian on lair
contact matthew@masot.net with questions or feedback