/* This file is part of cpp-ethereum. cpp-ethereum 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. cpp-ethereum 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 cpp-ethereum. If not, see . */ /** @file AddressState.h * @author Gav Wood * @date 2014 */ #pragma once #include "Common.h" #include "RLP.h" namespace eth { enum class AddressType { Dead, Normal, Contract }; class AddressState { public: AddressState(): m_type(AddressType::Dead), m_balance(0), m_nonce(0), m_haveMemory(false) {} AddressState(u256 _balance, u256 _nonce, AddressType _type = AddressType::Normal): m_type(_type), m_balance(_balance), m_nonce(_nonce), m_haveMemory(true) {} AddressState(u256 _balance, u256 _nonce, h256 _contractRoot): m_type(AddressType::Contract), m_balance(_balance), m_nonce(_nonce), m_haveMemory(false), m_contractRoot(_contractRoot) {} AddressState(u256 _balance, u256 _nonce, u256s _memory): m_type(AddressType::Contract), m_balance(_balance), m_nonce(_nonce), m_haveMemory(true) { for (unsigned i = 0; i < _memory.size(); ++i) #ifdef __clang__ { auto mFinder = m_memory.find((u256)i); if (mFinder == m_memory.end()) m_memory.insert(std::make_pair((u256)i,_memory[i])); else mFinder->second = _memory[i]; } #else m_memory[(u256)i] = _memory[i]; #endif } void incNonce() { m_nonce++; } void addBalance(bigint _i) { m_balance = (u256)((bigint)m_balance + _i); } void kill() { m_type = AddressType::Dead; m_memory.clear(); m_contractRoot = h256(); m_balance = 0; m_nonce = 0; } AddressType type() const { return m_type; } u256& balance() { return m_balance; } u256 const& balance() const { return m_balance; } u256& nonce() { return m_nonce; } u256 const& nonce() const { return m_nonce; } bool haveMemory() const { return m_haveMemory; } std::map& setHaveMemory() { assert(m_type == AddressType::Contract); m_haveMemory = true; m_contractRoot = h256(); return m_memory; } h256 oldRoot() const { assert(!haveMemory()); return m_contractRoot; } std::map& memory() { assert(m_type == AddressType::Contract && haveMemory()); return m_memory; } std::map const& memory() const { assert(m_type == AddressType::Contract && haveMemory()); return m_memory; } private: AddressType m_type; u256 m_balance; u256 m_nonce; bool m_haveMemory; h256 m_contractRoot; // TODO: change to unordered_map. std::map m_memory; }; }