|
|
|
/*
|
|
|
|
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 <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
/** @file AccountDiff.h
|
|
|
|
* @author Gav Wood <i@gavwood.com>
|
|
|
|
* @date 2014
|
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <libdevcore/Common.h>
|
|
|
|
#include <libdevcore/Diff.h>
|
|
|
|
#include <libethcore/Common.h>
|
|
|
|
|
|
|
|
namespace dev
|
|
|
|
{
|
|
|
|
namespace eth
|
|
|
|
{
|
|
|
|
|
|
|
|
/// Type of change that an account can have from state to state.
|
|
|
|
enum class AccountChange
|
|
|
|
{
|
|
|
|
None, ///< Nothing changed at all.
|
|
|
|
Creation, ///< Account came into existance.
|
|
|
|
Deletion, ///< Account was deleted.
|
|
|
|
Intrinsic, ///< Account was already in existance and some internal aspect of the account altered such as balance, nonce or storage.
|
|
|
|
CodeStorage, ///< Account was already in existance and the code of the account changed.
|
|
|
|
All ///< Account was already in existance and all aspects of the account changed.
|
|
|
|
};
|
|
|
|
|
|
|
|
/// @returns a three-character code that expresses the type of change.
|
|
|
|
char const* lead(AccountChange _c);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Stores the difference between two accounts (typically the same account at two times).
|
|
|
|
*
|
|
|
|
* In order to determine what about an account has altered, this struct can be used to specify
|
|
|
|
* alterations. Use changed() and changeType() to determine what, if anything, is different.
|
|
|
|
*
|
|
|
|
* Five members are accessible: to determine the nature of the changes.
|
|
|
|
*/
|
|
|
|
struct AccountDiff
|
|
|
|
{
|
|
|
|
/// @returns true if the account has changed at all.
|
|
|
|
inline bool changed() const { return storage.size() || code || nonce || balance || exist; }
|
|
|
|
/// @returns a three-character code that expresses the change.
|
|
|
|
AccountChange changeType() const;
|
|
|
|
|
|
|
|
Diff<bool> exist; ///< The account's existance; was it created/deleted or not?
|
|
|
|
Diff<u256> balance; ///< The account's balance; did it alter?
|
|
|
|
Diff<u256> nonce; ///< The account's nonce; did it alter?
|
|
|
|
std::unordered_map<u256, Diff<u256>> storage; ///< The account's storage addresses; each has its own Diff.
|
|
|
|
Diff<bytes> code; ///< The account's code; in general this should only have changed if exist also changed.
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Stores the difference between two states; this is just their encumbent accounts.
|
|
|
|
*/
|
|
|
|
struct StateDiff
|
|
|
|
{
|
|
|
|
std::map<Address, AccountDiff> accounts; ///< The state's account changes; each has its own AccountDiff.
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
/// Simple stream output for the StateDiff.
|
|
|
|
std::ostream& operator<<(std::ostream& _out, dev::eth::StateDiff const& _s);
|
|
|
|
/// Simple stream output for the AccountDiff.
|
|
|
|
std::ostream& operator<<(std::ostream& _out, dev::eth::AccountDiff const& _s);
|
|
|
|
|
|
|
|
}
|
|
|
|
|