diff options
author | chriseth <chris@ethereum.org> | 2017-07-14 17:49:27 +0800 |
---|---|---|
committer | chriseth <chris@ethereum.org> | 2017-08-23 23:37:35 +0800 |
commit | 75f09f2a84e556ca48b7bae00b459c77a0fa09fe (patch) | |
tree | 1244c883ba1a8c28689c4ecdc533616cdf0d3b02 /libsolidity/formal/SMTChecker.h | |
parent | 5bfd5d98c13b57c887eb09bffb9a03f2d1726b41 (diff) | |
download | dexon-solidity-75f09f2a84e556ca48b7bae00b459c77a0fa09fe.tar dexon-solidity-75f09f2a84e556ca48b7bae00b459c77a0fa09fe.tar.gz dexon-solidity-75f09f2a84e556ca48b7bae00b459c77a0fa09fe.tar.bz2 dexon-solidity-75f09f2a84e556ca48b7bae00b459c77a0fa09fe.tar.lz dexon-solidity-75f09f2a84e556ca48b7bae00b459c77a0fa09fe.tar.xz dexon-solidity-75f09f2a84e556ca48b7bae00b459c77a0fa09fe.tar.zst dexon-solidity-75f09f2a84e556ca48b7bae00b459c77a0fa09fe.zip |
Partial support for if statements.
Diffstat (limited to 'libsolidity/formal/SMTChecker.h')
-rw-r--r-- | libsolidity/formal/SMTChecker.h | 16 |
1 files changed, 16 insertions, 0 deletions
diff --git a/libsolidity/formal/SMTChecker.h b/libsolidity/formal/SMTChecker.h index f0968cc7..d4935116 100644 --- a/libsolidity/formal/SMTChecker.h +++ b/libsolidity/formal/SMTChecker.h @@ -46,6 +46,8 @@ private: virtual void endVisit(VariableDeclaration const& _node) override; virtual bool visit(FunctionDefinition const& _node) override; virtual void endVisit(FunctionDefinition const& _node) override; + virtual bool visit(IfStatement const& _node) override; + virtual bool visit(WhileStatement const& _node) override; virtual void endVisit(VariableDeclarationStatement const& _node) override; virtual void endVisit(ExpressionStatement const& _node) override; virtual void endVisit(Assignment const& _node) override; @@ -71,10 +73,23 @@ private: std::string uniqueSymbol(Declaration const& _decl); std::string uniqueSymbol(Expression const& _expr); + + /// @returns true if _delc is a variable that is known at the current point, i.e. + /// has a valid sequence number bool knownVariable(Declaration const& _decl); + /// @returns an expression denoting the value of the variable declared in @a _decl + /// at the current point. smt::Expression currentValue(Declaration const& _decl); + /// @returns an expression denoting the value of the variable declared in @a _decl + /// at the given sequence point. Does not ensure that this sequence point exists. + smt::Expression valueAtSequence(Declaration const& _decl, int _sequence); + /// Allocates a new sequence number for the declaration, updates the current + /// sequence number to this value and returns the expression. smt::Expression newValue(Declaration const& _decl); + /// Sets the value of the declaration either to zero or to its intrinsic range. + void setValue(Declaration const& _decl, bool _setToZero); + smt::Expression minValue(IntegerType const& _t); smt::Expression maxValue(IntegerType const& _t); @@ -87,6 +102,7 @@ private: std::shared_ptr<smt::SolverInterface> m_interface; std::map<Declaration const*, int> m_currentSequenceCounter; + std::map<Declaration const*, int> m_nextFreeSequenceCounter; std::map<Expression const*, smt::Expression> m_z3Expressions; std::map<Declaration const*, smt::Expression> m_z3Variables; ErrorReporter& m_errorReporter; |