diff options
author | Andrew Reynolds <andrew.j.reynolds@gmail.com> | 2020-12-02 16:59:11 -0600 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-12-02 14:59:11 -0800 |
commit | f7bdcfeb862aaf8156dca4aaec71aef9cdda1e56 (patch) | |
tree | 51054758afabaa12e9d49894743ad55dec7ce4fb /src/expr/record.cpp | |
parent | a9eaeb438882abd6d06be41c6fcb87f4f04bcc8c (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.cpp | 97 |
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 */ |