/* This file is part of solidity. solidity is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. solidity is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with solidity. If not, see . */ #include #include #include using namespace std; using namespace dev; using namespace dev::solidity; SymbolicVariable::SymbolicVariable( TypePointer _type, string const& _uniqueName, smt::SolverInterface& _interface ): m_type(move(_type)), m_uniqueName(_uniqueName), m_interface(_interface), m_ssa(make_shared()) { } smt::Expression SymbolicVariable::currentValue() const { return valueAtIndex(m_ssa->index()); } string SymbolicVariable::currentName() const { return uniqueSymbol(m_ssa->index()); } smt::Expression SymbolicVariable::valueAtIndex(int _index) const { return m_interface.newVariable(uniqueSymbol(_index), smtSort(*m_type)); } string SymbolicVariable::uniqueSymbol(unsigned _index) const { return m_uniqueName + "_" + to_string(_index); } smt::Expression SymbolicVariable::increaseIndex() { ++(*m_ssa); return currentValue(); } SymbolicBoolVariable::SymbolicBoolVariable( TypePointer _type, string const& _uniqueName, smt::SolverInterface&_interface ): SymbolicVariable(move(_type), _uniqueName, _interface) { solAssert(m_type->category() == Type::Category::Bool, ""); } SymbolicIntVariable::SymbolicIntVariable( TypePointer _type, string const& _uniqueName, smt::SolverInterface& _interface ): SymbolicVariable(move(_type), _uniqueName, _interface) { solAssert(isNumber(m_type->category()), ""); } SymbolicAddressVariable::SymbolicAddressVariable( string const& _uniqueName, smt::SolverInterface& _interface ): SymbolicIntVariable(make_shared(160), _uniqueName, _interface) { } SymbolicFixedBytesVariable::SymbolicFixedBytesVariable( unsigned _numBytes, string const& _uniqueName, smt::SolverInterface& _interface ): SymbolicIntVariable(make_shared(_numBytes * 8), _uniqueName, _interface) { } SymbolicFunctionVariable::SymbolicFunctionVariable( TypePointer _type, string const& _uniqueName, smt::SolverInterface&_interface ): SymbolicVariable(move(_type), _uniqueName, _interface), m_declaration(m_interface.newVariable(currentName(), smtSort(*m_type))) { solAssert(m_type->category() == Type::Category::Function, ""); } void SymbolicFunctionVariable::resetDeclaration() { m_declaration = m_interface.newVariable(currentName(), smtSort(*m_type)); } smt::Expression SymbolicFunctionVariable::increaseIndex() { ++(*m_ssa); resetDeclaration(); return currentValue(); } smt::Expression SymbolicFunctionVariable::operator()(vector _arguments) const { return m_declaration(_arguments); } SymbolicMappingVariable::SymbolicMappingVariable( TypePointer _type, string const& _uniqueName, smt::SolverInterface& _interface ): SymbolicVariable(move(_type), _uniqueName, _interface) { solAssert(isMapping(m_type->category()), ""); }