diff options
author | Morgan Deters <mdeters@gmail.com> | 2012-11-27 02:13:38 +0000 |
---|---|---|
committer | Morgan Deters <mdeters@gmail.com> | 2012-11-27 02:13:38 +0000 |
commit | b122cec27ca27d0b48e786191448e0053be78ed0 (patch) | |
tree | 615981d8623e830894f02fc528b173ac7461f934 /src/parser/parser.cpp | |
parent | 3da16da97df7cd2efd4b113db3bfef8b9c138ebe (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/parser/parser.cpp')
-rw-r--r-- | src/parser/parser.cpp | 37 |
1 files changed, 3 insertions, 34 deletions
diff --git a/src/parser/parser.cpp b/src/parser/parser.cpp index ef386f57e..10ca16001 100644 --- a/src/parser/parser.cpp +++ b/src/parser/parser.cpp @@ -138,8 +138,8 @@ bool Parser::isPredicate(const std::string& name) { Expr Parser::mkVar(const std::string& name, const Type& type, bool levelZero) { - Debug("parser") << "mkVar(" << name << ", " << type << ")" << std::endl; - Expr expr = d_exprManager->mkVar(name, type); + Debug("parser") << "mkVar(" << name << ", " << type << ", " << levelZero << ")" << std::endl; + Expr expr = d_exprManager->mkVar(name, type, levelZero); defineVar(name, expr, levelZero); return expr; } @@ -156,7 +156,7 @@ Expr Parser::mkFunction(const std::string& name, const Type& type, bool levelZero) { Debug("parser") << "mkVar(" << name << ", " << type << ")" << std::endl; - Expr expr = d_exprManager->mkVar(name, type); + Expr expr = d_exprManager->mkVar(name, type, levelZero); defineFunction(name, expr, levelZero); return expr; } @@ -339,37 +339,6 @@ Parser::mkMutualDatatypeTypes(const std::vector<Datatype>& datatypes) { return types; } -DatatypeType Parser::mkRecordType(const std::vector< std::pair<std::string, Type> >& typeIds) { - DatatypeType& dtt = d_recordTypes[typeIds]; - if(dtt.isNull()) { - Datatype dt("__cvc4_record"); -Debug("datatypes") << "make new record_ctor" << std::endl; - DatatypeConstructor c("__cvc4_record_ctor"); - for(std::vector< std::pair<std::string, Type> >::const_iterator i = typeIds.begin(); i != typeIds.end(); ++i) { - c.addArg((*i).first, (*i).second); - } - dt.addConstructor(c); - dtt = d_exprManager->mkDatatypeType(dt); - } else { -Debug("datatypes") << "use old record_ctor" << std::endl; -} - return dtt; -} - -DatatypeType Parser::mkTupleType(const std::vector<Type>& types) { - DatatypeType& dtt = d_tupleTypes[types]; - if(dtt.isNull()) { - Datatype dt("__cvc4_tuple"); - DatatypeConstructor c("__cvc4_tuple_ctor"); - for(std::vector<Type>::const_iterator i = types.begin(); i != types.end(); ++i) { - c.addArg("__cvc4_tuple_stor", *i); - } - dt.addConstructor(c); - dtt = d_exprManager->mkDatatypeType(dt); - } - return dtt; -} - bool Parser::isDeclared(const std::string& name, SymbolType type) { switch(type) { case SYM_VARIABLE: |