summaryrefslogtreecommitdiff
path: root/src/expr/node_manager.cpp
diff options
context:
space:
mode:
authorMorgan Deters <mdeters@gmail.com>2012-11-27 02:13:38 +0000
committerMorgan Deters <mdeters@gmail.com>2012-11-27 02:13:38 +0000
commitb122cec27ca27d0b48e786191448e0053be78ed0 (patch)
tree615981d8623e830894f02fc528b173ac7461f934 /src/expr/node_manager.cpp
parent3da16da97df7cd2efd4b113db3bfef8b9c138ebe (diff)
Tuples and records merge. Resolves bug 270.
Also some fixes to parametric datatypes I found, and fixes for a handful of bugs, including some observed with --check-models --incremental on together. (this commit was certified error- and warning-free by the test-and-commit script.)
Diffstat (limited to 'src/expr/node_manager.cpp')
-rw-r--r--src/expr/node_manager.cpp36
1 files changed, 35 insertions, 1 deletions
diff --git a/src/expr/node_manager.cpp b/src/expr/node_manager.cpp
index 0a13222dd..f040c7c72 100644
--- a/src/expr/node_manager.cpp
+++ b/src/expr/node_manager.cpp
@@ -320,7 +320,7 @@ Node NodeManager::mkSkolem(const std::string& name, const TypeNode& type, const
}
if((flags & SKOLEM_NO_NOTIFY) == 0) {
for(vector<NodeManagerListener*>::iterator i = d_listeners.begin(); i != d_listeners.end(); ++i) {
- (*i)->nmNotifyNewSkolem(n, comment);
+ (*i)->nmNotifyNewSkolem(n, comment, (flags & SKOLEM_IS_GLOBAL) == SKOLEM_IS_GLOBAL);
}
}
return n;
@@ -395,4 +395,38 @@ TypeNode NodeManager::mkSubrangeType(const SubrangeBounds& bounds)
return TypeNode(mkTypeConst(bounds));
}
+TypeNode NodeManager::getDatatypeForTupleRecord(TypeNode t) {
+ Assert(t.isTuple() || t.isRecord());
+
+ // if the type doesn't have an associated datatype, then make one for it
+ TypeNode& dtt = d_tupleAndRecordTypes[t];
+ if(dtt.isNull()) {
+ if(t.isTuple()) {
+ Datatype dt("__cvc4_tuple");
+ DatatypeConstructor c("__cvc4_tuple_ctor");
+ for(TypeNode::const_iterator i = t.begin(); i != t.end(); ++i) {
+ c.addArg("__cvc4_tuple_stor", (*i).toType());
+ }
+ dt.addConstructor(c);
+ dtt = TypeNode::fromType(toExprManager()->mkDatatypeType(dt));
+ Debug("tuprec") << "REWROTE " << t << " to " << dtt << std::endl;
+ } else {
+ const Record& rec = t.getRecord();
+ Datatype dt("__cvc4_record");
+ DatatypeConstructor c("__cvc4_record_ctor");
+ for(Record::const_iterator i = rec.begin(); i != rec.end(); ++i) {
+ c.addArg((*i).first, (*i).second);
+ }
+ dt.addConstructor(c);
+ dtt = TypeNode::fromType(toExprManager()->mkDatatypeType(dt));
+ Debug("tuprec") << "REWROTE " << t << " to " << dtt << std::endl;
+ }
+ dtt.setAttribute(DatatypeRecordAttr(), t);
+ } else {
+ Debug("tuprec") << "REUSING cached " << t << ": " << dtt << std::endl;
+ }
+ Assert(!dtt.isNull());
+ return dtt;
+}
+
}/* CVC4 namespace */
generated by cgit on debian on lair
contact matthew@masot.net with questions or feedback