summaryrefslogtreecommitdiff
path: root/src/util/command.h
diff options
context:
space:
mode:
authorDejan Jovanović <dejan.jovanovic@gmail.com>2009-12-06 02:21:46 +0000
committerDejan Jovanović <dejan.jovanovic@gmail.com>2009-12-06 02:21:46 +0000
commitc16be5841e613818d5764e4de99e4694a0703685 (patch)
tree5bf7c07a8f7200c2830d50f5dd83ecbb4f02444d /src/util/command.h
parent200f36785acf7aac3e7e230795ea7ffdb6b1ed64 (diff)
Big chunk of changes:
* Fixed bugs in option parsing * Simplified the main.cpp significantly (more c++ like) * Added the null kind, expr value, and expression, with the default constructor public * Simplified commands, we need to discuss this in the meeting (what to do with command results?) * Removed all the lex/yacc files * Symbol table is now a templated class, as we will have tables for variables, predicates and functions * The ANTLR parsing infrastructure/makefiles is all in. SMT lib Boolean benchmarks should parse + giving nice error such as Parse Error: /home/dejan/eclipse-cxx/smtlib-parser/test/test4.smt:3:16: Undeclared variable p Parse Error: /home/dejan/eclipse-cxx/smtlib-parser/test/test2.smt:2:11: unexpected token: sa Didn't add any unit tests as the unit testing doesn't work with the updated build system -- it doesn't know how to create directories in the corresponding build directory. TODO: * add the PL grammar and unit test when the testing becomes available * with this build setup my eclipse debugger doesn't work. Might have something to do with the visibility of symbols? * i'm getting g++ depracated warnings regarding the hash_map from the symbol table, need to figure out how to use it in a standard manner. the new <unordered_map> header is for C++0x, and the <ext/hash_map> is getting deprecation warningns... weird.
Diffstat (limited to 'src/util/command.h')
-rw-r--r--src/util/command.h44
1 files changed, 12 insertions, 32 deletions
diff --git a/src/util/command.h b/src/util/command.h
index c65429fdb..ce137896a 100644
--- a/src/util/command.h
+++ b/src/util/command.h
@@ -16,7 +16,6 @@
#include "cvc4_config.h"
#include "expr/expr.h"
-#include "util/result.h"
namespace CVC4 {
class SmtEngine;
@@ -25,15 +24,14 @@ namespace CVC4 {
}/* CVC4 namespace */
namespace std {
-inline std::ostream& operator<<(std::ostream&, const CVC4::Command*) CVC4_PUBLIC;
-inline std::ostream& operator<<(std::ostream&, CVC4::Expr) CVC4_PUBLIC;
+ std::ostream& operator<<(std::ostream&, const CVC4::Command&) CVC4_PUBLIC;
}
namespace CVC4 {
class CVC4_PUBLIC Command {
public:
- virtual Result invoke(CVC4::SmtEngine* smt_engine) = 0;
+ virtual void invoke(CVC4::SmtEngine* smt_engine) = 0;
virtual ~Command() {};
virtual void toString(std::ostream&) const = 0;
};/* class Command */
@@ -41,8 +39,8 @@ public:
class CVC4_PUBLIC EmptyCommand : public Command {
public:
EmptyCommand();
- Result invoke(CVC4::SmtEngine* smt_engine);
- void toString(std::ostream& out) const { out << "EmptyCommand"; }
+ void invoke(CVC4::SmtEngine* smt_engine);
+ void toString(std::ostream& out) const;
};/* class EmptyCommand */
@@ -51,8 +49,8 @@ protected:
Expr d_expr;
public:
AssertCommand(const Expr& e);
- Result invoke(CVC4::SmtEngine* smt_engine);
- void toString(std::ostream& out) const { out << "Assert(" << d_expr << ")"; }
+ void invoke(CVC4::SmtEngine* smt_engine);
+ void toString(std::ostream& out) const;
};/* class AssertCommand */
@@ -60,8 +58,8 @@ class CVC4_PUBLIC CheckSatCommand : public Command {
public:
CheckSatCommand();
CheckSatCommand(const Expr& e);
- Result invoke(SmtEngine* smt);
- void toString(std::ostream& out) const { out << "CheckSat(" << d_expr << ")"; }
+ void invoke(SmtEngine* smt);
+ void toString(std::ostream& out) const;
protected:
Expr d_expr;
};/* class CheckSatCommand */
@@ -70,8 +68,8 @@ protected:
class CVC4_PUBLIC QueryCommand : public Command {
public:
QueryCommand(const Expr& e);
- Result invoke(SmtEngine* smt);
- void toString(std::ostream& out) const { out << "Query(" << d_expr << ")"; }
+ void invoke(SmtEngine* smt);
+ void toString(std::ostream& out) const;
protected:
Expr d_expr;
};/* class QueryCommand */
@@ -80,21 +78,10 @@ protected:
class CVC4_PUBLIC CommandSequence : public Command {
public:
CommandSequence();
- CommandSequence(Command* cmd);
~CommandSequence();
- Result invoke(SmtEngine* smt);
+ void invoke(SmtEngine* smt);
void addCommand(Command* cmd);
- void toString(std::ostream& out) const {
- out << "CommandSequence(";
- for(std::vector<Command*>::const_iterator i = d_command_sequence.begin();
- i != d_command_sequence.end();
- ++i) {
- out << *i;
- if(i != d_command_sequence.end())
- out << " ; ";
- }
- out << ")";
- }
+ void toString(std::ostream& out) const;
private:
/** All the commands to be executed (in sequence) */
std::vector<Command*> d_command_sequence;
@@ -104,11 +91,4 @@ private:
}/* CVC4 namespace */
-inline std::ostream& std::operator<<(std::ostream& out, const CVC4::Command* c) {
- if(c)
- c->toString(out);
- else out << "(null)";
- return out;
-}
-
#endif /* __CVC4__COMMAND_H */
generated by cgit on debian on lair
contact matthew@masot.net with questions or feedback