summaryrefslogtreecommitdiff
path: root/src/expr/record.cpp
diff options
context:
space:
mode:
authorAndrew Reynolds <andrew.j.reynolds@gmail.com>2020-12-02 16:59:11 -0600
committerGitHub <noreply@github.com>2020-12-02 14:59:11 -0800
commitf7bdcfeb862aaf8156dca4aaec71aef9cdda1e56 (patch)
tree51054758afabaa12e9d49894743ad55dec7ce4fb /src/expr/record.cpp
parenta9eaeb438882abd6d06be41c6fcb87f4f04bcc8c (diff)
Remove Record object and convert to Node-level API (#5575)
Required for detangling NodeManager from the Expr layer.
Diffstat (limited to 'src/expr/record.cpp')
-rw-r--r--src/expr/record.cpp97
1 files changed, 0 insertions, 97 deletions
diff --git a/src/expr/record.cpp b/src/expr/record.cpp
index f4004d2e7..08944912a 100644
--- a/src/expr/record.cpp
+++ b/src/expr/record.cpp
@@ -18,109 +18,12 @@
#include "base/check.h"
#include "base/output.h"
-#include "expr/expr.h"
-#include "expr/type.h"
namespace CVC4 {
-static Record::FieldVector::const_iterator find(
- const Record::FieldVector& fields, const std::string& name)
-{
- for(Record::FieldVector::const_iterator i = fields.begin(), i_end = fields.end(); i != i_end; ++i){
- if((*i).first == name) {
- return i;
- }
- }
- return fields.end();
-}
-
-Record::Record(const FieldVector& fields)
- : d_fields(new FieldVector(fields))
-{
- Debug("record") << "making " << this << " " << d_fields << std::endl;
-}
-
-Record::Record(const Record& other)
- : d_fields(new FieldVector(other.getFields()))
-{
- Debug("record") << "copy constructor " << this << " " << d_fields << std::endl;
-}
-
-Record::~Record() {
- Debug("record") << "deleting " << this << " " << d_fields << std::endl;
- delete d_fields;
-}
-
-Record& Record::operator=(const Record& r) {
- Debug("record") << "setting " << this << " " << d_fields << std::endl;
- Record::FieldVector& local = *d_fields;
- local = r.getFields();
- return *this;
-}
-
-const Record::FieldVector& Record::getFields() const {
- return *d_fields;
-}
-
-bool Record::contains(const std::string& name) const {
- return find(*d_fields, name) != d_fields->end();
-}
-
-
-size_t Record::getIndex(std::string name) const {
- FieldVector::const_iterator i = find(*d_fields, name);
- PrettyCheckArgument(i != d_fields->end(), name,
- "requested field `%s' does not exist in record",
- name.c_str());
- return i - d_fields->begin();
-}
-
-size_t Record::getNumFields() const {
- return d_fields->size();
-}
-
-
-std::ostream& operator<<(std::ostream& os, const Record& r) {
- os << "[# ";
- bool first = true;
- const Record::FieldVector& fields = r.getFields();
- for(Record::FieldVector::const_iterator i = fields.begin(),
- i_end = fields.end(); i != i_end; ++i) {
- if(!first) {
- os << ", ";
- }
- os << (*i).first << ":" << (*i).second;
- first = false;
- }
- os << " #]";
-
- return os;
-}
-
-size_t RecordHashFunction::operator()(const Record& r) const {
- size_t n = 0;
- const Record::FieldVector& fields = r.getFields();
- for(Record::FieldVector::const_iterator i = fields.begin(),
- i_end = fields.end(); i != i_end; ++i) {
- n = (n << 3) ^ TypeHashFunction()((*i).second);
- }
- return n;
-}
-
std::ostream& operator<<(std::ostream& out, const RecordUpdate& t) {
return out << "[" << t.getField() << "]";
}
-
-const std::pair<std::string, Type>& Record::operator[](size_t index) const {
- PrettyCheckArgument(index < d_fields->size(), index,
- "index out of bounds for record type");
- return (*d_fields)[index];
-}
-
-bool Record::operator==(const Record& r) const {
- return (*d_fields) == *(r.d_fields);
-}
-
}/* CVC4 namespace */
generated by cgit on debian on lair
contact matthew@masot.net with questions or feedback