From 6999ad2dd15051addb8b8aed083943eb3706598b Mon Sep 17 00:00:00 2001 From: Prathmesh Ranaut Date: Thu, 20 Apr 2023 01:01:03 +0530 Subject: [PATCH] Added isort to pyenv --- Makefile | 4 + eth/_utils/address.py | 9 +- eth/_utils/blake2/coders.py | 4 +- eth/_utils/bn128.py | 15 +-- eth/_utils/datatypes.py | 22 +++-- eth/_utils/env.py | 2 - eth/_utils/generator.py | 1 - eth/_utils/headers.py | 12 ++- eth/_utils/module_loading.py | 5 +- eth/_utils/numeric.py | 8 +- eth/_utils/padding.py | 1 - eth/_utils/rlp.py | 11 +-- eth/_utils/spoof.py | 11 +-- eth/_utils/state.py | 4 +- eth/_utils/transactions.py | 30 +++--- eth/_utils/version.py | 4 +- eth/_warnings.py | 8 +- eth/abc.py | 29 +++--- eth/chains/base.py | 38 ++++---- eth/chains/goerli/constants.py | 5 +- eth/chains/header.py | 8 +- eth/chains/mainnet/constants.py | 5 +- eth/chains/ropsten/constants.py | 5 +- eth/consensus/clique/_utils.py | 14 ++- eth/consensus/clique/clique.py | 29 +++--- eth/consensus/clique/constants.py | 4 +- eth/consensus/clique/datatypes.py | 6 +- eth/consensus/clique/encoding.py | 8 +- eth/consensus/clique/exceptions.py | 4 +- eth/consensus/clique/snapshot_manager.py | 41 +++++---- eth/consensus/noproof.py | 1 + eth/consensus/pos.py | 1 + eth/consensus/pow.py | 15 ++- eth/constants.py | 16 +++- eth/db/accesslog.py | 14 +-- eth/db/account.py | 41 +++++---- eth/db/atomic.py | 14 ++- eth/db/backends/level.py | 20 ++-- eth/db/batch.py | 8 +- eth/db/cache.py | 12 ++- eth/db/chain.py | 55 +++++++---- eth/db/chain_gaps.py | 18 +++- eth/db/diff.py | 14 ++- eth/db/hash_trie.py | 10 +- eth/db/header.py | 43 +++++---- eth/db/journal.py | 32 +++++-- eth/db/keymap.py | 9 +- eth/db/schema.py | 4 +- eth/db/slow_journal.py | 26 ++++-- eth/db/storage.py | 10 +- eth/db/trie.py | 12 ++- eth/estimators/gas.py | 18 +++- eth/exceptions.py | 4 +- eth/precompiles/blake2.py | 12 ++- eth/precompiles/ecadd.py | 19 ++-- eth/precompiles/ecmul.py | 21 +++-- eth/precompiles/ecpairing.py | 27 +++--- eth/precompiles/ecrecover.py | 15 +-- eth/precompiles/identity.py | 5 +- eth/precompiles/modexp.py | 8 +- eth/precompiles/ripemd160.py | 5 +- eth/precompiles/sha256.py | 6 +- eth/rlp/accounts.py | 14 ++- eth/rlp/headers.py | 29 +++--- eth/rlp/logs.py | 13 +-- eth/rlp/receipts.py | 14 ++- eth/rlp/sedes.py | 1 - eth/rlp/transactions.py | 22 +++-- eth/tools/_utils/deprecation.py | 3 +- eth/tools/_utils/git.py | 4 +- eth/tools/_utils/hashing.py | 8 +- eth/tools/_utils/mappings.py | 9 +- eth/tools/_utils/normalization.py | 33 +++---- eth/tools/_utils/slow_code_stream.py | 6 +- eth/tools/_utils/vyper.py | 7 +- eth/tools/builder/chain/builders.py | 56 +++++++----- eth/tools/db/atomic.py | 8 +- eth/tools/db/base.py | 4 +- eth/tools/factories/keys.py | 12 ++- eth/tools/factories/transaction.py | 4 +- eth/tools/fixtures/_utils.py | 5 +- eth/tools/fixtures/fillers/_utils.py | 12 ++- eth/tools/fixtures/fillers/common.py | 25 +++-- eth/tools/fixtures/fillers/formatters.py | 6 +- eth/tools/fixtures/fillers/main.py | 13 ++- eth/tools/fixtures/fillers/state.py | 49 +++++++--- eth/tools/fixtures/fillers/vm.py | 12 ++- eth/tools/fixtures/generation.py | 1 - eth/tools/fixtures/helpers.py | 39 ++++---- eth/tools/fixtures/loading.py | 6 +- eth/tools/mining.py | 2 +- eth/tools/rlp.py | 3 +- eth/typing.py | 4 +- eth/validation.py | 23 +++-- eth/vm/base.py | 30 +++--- eth/vm/chain_context.py | 8 +- eth/vm/code_stream.py | 6 +- eth/vm/computation.py | 28 +++--- eth/vm/execution_context.py | 8 +- eth/vm/forks/arrow_glacier/blocks.py | 18 ++-- eth/vm/forks/arrow_glacier/computation.py | 4 +- eth/vm/forks/arrow_glacier/headers.py | 27 ++++-- eth/vm/forks/arrow_glacier/state.py | 21 ++++- eth/vm/forks/arrow_glacier/transactions.py | 8 +- eth/vm/forks/berlin/blocks.py | 4 +- eth/vm/forks/berlin/computation.py | 20 ++-- eth/vm/forks/berlin/headers.py | 3 +- eth/vm/forks/berlin/logic.py | 18 +++- eth/vm/forks/berlin/opcodes.py | 32 ++++--- eth/vm/forks/berlin/receipts.py | 17 +++- eth/vm/forks/berlin/state.py | 10 +- eth/vm/forks/berlin/transactions.py | 51 +++++++---- eth/vm/forks/byzantium/blocks.py | 1 + eth/vm/forks/byzantium/computation.py | 16 +++- eth/vm/forks/byzantium/constants.py | 4 +- eth/vm/forks/byzantium/headers.py | 21 +++-- eth/vm/forks/byzantium/opcodes.py | 37 +++++--- eth/vm/forks/byzantium/state.py | 8 +- eth/vm/forks/byzantium/transactions.py | 9 +- eth/vm/forks/constantinople/blocks.py | 1 + eth/vm/forks/constantinople/computation.py | 12 +-- eth/vm/forks/constantinople/constants.py | 5 +- eth/vm/forks/constantinople/headers.py | 3 +- eth/vm/forks/constantinople/opcodes.py | 12 +-- eth/vm/forks/constantinople/state.py | 6 +- eth/vm/forks/constantinople/storage.py | 6 +- eth/vm/forks/constantinople/transactions.py | 15 +-- eth/vm/forks/frontier/blocks.py | 9 +- eth/vm/forks/frontier/computation.py | 23 +++-- eth/vm/forks/frontier/headers.py | 37 ++++---- eth/vm/forks/frontier/opcodes.py | 20 ++-- eth/vm/forks/frontier/state.py | 35 ++++--- eth/vm/forks/frontier/transaction_context.py | 4 +- eth/vm/forks/frontier/transactions.py | 51 ++++++----- eth/vm/forks/gray_glacier/blocks.py | 22 +++-- eth/vm/forks/gray_glacier/computation.py | 4 +- eth/vm/forks/gray_glacier/headers.py | 19 ++-- eth/vm/forks/gray_glacier/state.py | 21 ++++- eth/vm/forks/gray_glacier/transactions.py | 8 +- eth/vm/forks/homestead/blocks.py | 2 + eth/vm/forks/homestead/computation.py | 17 ++-- eth/vm/forks/homestead/headers.py | 22 +++-- eth/vm/forks/homestead/opcodes.py | 28 ++++-- eth/vm/forks/homestead/state.py | 12 ++- eth/vm/forks/homestead/transactions.py | 31 ++++--- eth/vm/forks/homestead/validation.py | 7 +- eth/vm/forks/istanbul/blocks.py | 1 + eth/vm/forks/istanbul/computation.py | 14 +-- eth/vm/forks/istanbul/headers.py | 3 +- eth/vm/forks/istanbul/opcodes.py | 24 +++-- eth/vm/forks/istanbul/state.py | 6 +- eth/vm/forks/istanbul/storage.py | 14 ++- eth/vm/forks/istanbul/transactions.py | 21 +++-- eth/vm/forks/london/blocks.py | 14 +-- eth/vm/forks/london/computation.py | 12 ++- eth/vm/forks/london/headers.py | 17 +++- eth/vm/forks/london/opcodes.py | 29 +++--- eth/vm/forks/london/receipts.py | 10 +- eth/vm/forks/london/state.py | 30 ++++-- eth/vm/forks/london/storage.py | 9 +- eth/vm/forks/london/transactions.py | 36 ++++++-- eth/vm/forks/london/validation.py | 6 +- eth/vm/forks/muir_glacier/blocks.py | 1 + eth/vm/forks/muir_glacier/computation.py | 8 +- eth/vm/forks/muir_glacier/headers.py | 7 +- eth/vm/forks/muir_glacier/opcodes.py | 2 +- eth/vm/forks/muir_glacier/state.py | 6 +- eth/vm/forks/muir_glacier/transactions.py | 15 +-- eth/vm/forks/paris/blocks.py | 19 ++-- eth/vm/forks/paris/computation.py | 9 +- eth/vm/forks/paris/headers.py | 26 ++++-- eth/vm/forks/paris/opcodes.py | 32 +++++-- eth/vm/forks/paris/state.py | 22 ++++- eth/vm/forks/paris/transactions.py | 8 +- eth/vm/forks/petersburg/blocks.py | 1 + eth/vm/forks/petersburg/computation.py | 10 +- eth/vm/forks/petersburg/constants.py | 5 +- eth/vm/forks/petersburg/headers.py | 3 +- eth/vm/forks/petersburg/opcodes.py | 17 ++-- eth/vm/forks/petersburg/state.py | 6 +- eth/vm/forks/petersburg/transactions.py | 15 +-- eth/vm/forks/shanghai/blocks.py | 91 +++++++++++++------ eth/vm/forks/shanghai/computation.py | 24 +++-- eth/vm/forks/shanghai/constants.py | 4 +- eth/vm/forks/shanghai/headers.py | 22 +++-- eth/vm/forks/shanghai/logic.py | 9 +- eth/vm/forks/shanghai/opcodes.py | 41 ++++++--- eth/vm/forks/shanghai/state.py | 17 +++- eth/vm/forks/shanghai/transactions.py | 8 +- eth/vm/forks/shanghai/withdrawals.py | 32 +++++-- eth/vm/forks/spurious_dragon/_utils.py | 24 +++-- eth/vm/forks/spurious_dragon/blocks.py | 2 + eth/vm/forks/spurious_dragon/computation.py | 17 +++- eth/vm/forks/spurious_dragon/opcodes.py | 33 ++++--- eth/vm/forks/spurious_dragon/state.py | 12 ++- eth/vm/forks/spurious_dragon/transactions.py | 22 +++-- eth/vm/forks/tangerine_whistle/computation.py | 9 +- eth/vm/forks/tangerine_whistle/opcodes.py | 27 ++++-- eth/vm/forks/tangerine_whistle/state.py | 8 +- eth/vm/gas_meter.py | 5 +- eth/vm/header.py | 4 +- eth/vm/logic/arithmetic.py | 14 +-- eth/vm/logic/block.py | 4 +- eth/vm/logic/call.py | 16 ++-- eth/vm/logic/comparison.py | 10 +- eth/vm/logic/context.py | 25 ++--- eth/vm/logic/duplication.py | 4 +- eth/vm/logic/flow.py | 9 +- eth/vm/logic/invalid.py | 12 ++- eth/vm/logic/logging.py | 14 ++- eth/vm/logic/memory.py | 4 +- eth/vm/logic/sha3.py | 12 ++- eth/vm/logic/stack.py | 4 +- eth/vm/logic/storage.py | 12 ++- eth/vm/logic/swap.py | 4 +- eth/vm/logic/system.py | 26 ++++-- eth/vm/memory.py | 11 ++- eth/vm/message.py | 12 ++- eth/vm/opcode.py | 6 +- eth/vm/spoof.py | 14 ++- eth/vm/stack.py | 10 +- eth/vm/state.py | 14 ++- eth/vm/transaction_context.py | 8 +- tox.ini | 1 + 224 files changed, 2052 insertions(+), 1213 deletions(-) diff --git a/Makefile b/Makefile index 92e9582d36..44dd4f4cfc 100644 --- a/Makefile +++ b/Makefile @@ -29,6 +29,10 @@ lint-roll: isort eth $(MAKE) lint +lint-roll: + isort --recursive eth scripts tests + $(MAKE) lint + test: py.test --tb native tests diff --git a/eth/_utils/address.py b/eth/_utils/address.py index 54f6943c57..66a5a3925d 100644 --- a/eth/_utils/address.py +++ b/eth/_utils/address.py @@ -1,8 +1,11 @@ +from eth_hash.auto import ( + keccak, +) +from eth_typing import ( + Address, +) import rlp -from eth_hash.auto import keccak -from eth_typing import Address - from eth._utils.numeric import ( int_to_bytes32, ) diff --git a/eth/_utils/blake2/coders.py b/eth/_utils/blake2/coders.py index 02a9520314..9c40168587 100644 --- a/eth/_utils/blake2/coders.py +++ b/eth/_utils/blake2/coders.py @@ -1,13 +1,13 @@ from typing import ( - cast, Iterable, Tuple, + cast, ) from eth_utils import ( + ValidationError, to_int, to_tuple, - ValidationError, ) from .compression import ( diff --git a/eth/_utils/bn128.py b/eth/_utils/bn128.py index a1a31a4092..d117dd7588 100644 --- a/eth/_utils/bn128.py +++ b/eth/_utils/bn128.py @@ -1,17 +1,18 @@ +from typing import ( + Tuple, +) + +from eth_utils import ( + ValidationError, +) from py_ecc import ( optimized_bn128 as bn128, ) from py_ecc.optimized_bn128 import ( - FQP, FQ2, + FQP, ) -from eth_utils import ( - ValidationError, -) - -from typing import Tuple - def validate_point(x: int, y: int) -> Tuple[bn128.FQ, bn128.FQ, bn128.FQ]: FQ = bn128.FQ diff --git a/eth/_utils/datatypes.py b/eth/_utils/datatypes.py index 8dd7b84d09..87894c134d 100644 --- a/eth/_utils/datatypes.py +++ b/eth/_utils/datatypes.py @@ -1,17 +1,25 @@ -from eth_utils.toolz import ( - assoc, - groupby, +from typing import ( + Any, + Dict, + Iterator, + List, + Tuple, + Type, + TypeVar, ) from eth_utils import ( to_dict, to_set, ) +from eth_utils.toolz import ( + assoc, + groupby, +) - -from typing import Any, Dict, Tuple, Type, TypeVar, Iterator, List - -from eth.abc import ConfigurableAPI +from eth.abc import ( + ConfigurableAPI, +) def _is_local_prop(prop: str) -> bool: diff --git a/eth/_utils/env.py b/eth/_utils/env.py index 8e049b7a27..9ad130829b 100644 --- a/eth/_utils/env.py +++ b/eth/_utils/env.py @@ -4,7 +4,6 @@ """ import os - from typing import ( Any, Callable, @@ -16,7 +15,6 @@ Union, ) - # No set literals because we support Python 2.6. TRUE_VALUES = { True, diff --git a/eth/_utils/generator.py b/eth/_utils/generator.py index 5f1b52276f..0cb26fbe96 100644 --- a/eth/_utils/generator.py +++ b/eth/_utils/generator.py @@ -7,7 +7,6 @@ TypeVar, ) - TItem = TypeVar('TItem') diff --git a/eth/_utils/headers.py b/eth/_utils/headers.py index a91dec309b..0252b6a990 100644 --- a/eth/_utils/headers.py +++ b/eth/_utils/headers.py @@ -9,17 +9,19 @@ Address, ) -from eth.abc import BlockHeaderAPI +from eth.abc import ( + BlockHeaderAPI, +) from eth.constants import ( BLANK_ROOT_HASH, - GENESIS_BLOCK_NUMBER, - GENESIS_PARENT_HASH, - GAS_LIMIT_EMA_DENOMINATOR, GAS_LIMIT_ADJUSTMENT_FACTOR, + GAS_LIMIT_EMA_DENOMINATOR, GAS_LIMIT_MAXIMUM, GAS_LIMIT_MINIMUM, - GAS_LIMIT_USAGE_ADJUSTMENT_NUMERATOR, GAS_LIMIT_USAGE_ADJUSTMENT_DENOMINATOR, + GAS_LIMIT_USAGE_ADJUSTMENT_NUMERATOR, + GENESIS_BLOCK_NUMBER, + GENESIS_PARENT_HASH, ZERO_ADDRESS, ) from eth.typing import ( diff --git a/eth/_utils/module_loading.py b/eth/_utils/module_loading.py index d824a3db84..1bae37d5ab 100644 --- a/eth/_utils/module_loading.py +++ b/eth/_utils/module_loading.py @@ -1,6 +1,7 @@ +from importlib import ( + import_module, +) import operator -from importlib import import_module - from types import ( ModuleType, ) diff --git a/eth/_utils/numeric.py b/eth/_utils/numeric.py index 80819b9217..e6a25a11ed 100644 --- a/eth/_utils/numeric.py +++ b/eth/_utils/numeric.py @@ -5,17 +5,17 @@ Union, ) -from eth_utils.toolz import ( - curry, -) from eth_typing import ( Hash32, ) +from eth_utils.toolz import ( + curry, +) from eth.constants import ( UINT_255_MAX, - UINT_256_MAX, UINT_256_CEILING, + UINT_256_MAX, ) diff --git a/eth/_utils/padding.py b/eth/_utils/padding.py index 977963ef8e..30b21c39d0 100644 --- a/eth/_utils/padding.py +++ b/eth/_utils/padding.py @@ -2,7 +2,6 @@ curry, ) - ZERO_BYTE = b'\x00' diff --git a/eth/_utils/rlp.py b/eth/_utils/rlp.py index f737dd83b9..9c8edde72e 100644 --- a/eth/_utils/rlp.py +++ b/eth/_utils/rlp.py @@ -1,18 +1,17 @@ -import rlp from typing import ( Iterable, Optional, Tuple, ) -from eth_utils.toolz import ( - curry, -) - from eth_utils import ( - to_tuple, ValidationError, + to_tuple, ) +from eth_utils.toolz import ( + curry, +) +import rlp from eth.rlp.blocks import ( BaseBlock, diff --git a/eth/_utils/spoof.py b/eth/_utils/spoof.py index 9689b59ed5..97bd957770 100644 --- a/eth/_utils/spoof.py +++ b/eth/_utils/spoof.py @@ -8,16 +8,15 @@ merge, ) -from eth.constants import ( - DEFAULT_SPOOF_Y_PARITY, - DEFAULT_SPOOF_R, - DEFAULT_SPOOF_S, -) - from eth.abc import ( SignedTransactionAPI, UnsignedTransactionAPI, ) +from eth.constants import ( + DEFAULT_SPOOF_R, + DEFAULT_SPOOF_S, + DEFAULT_SPOOF_Y_PARITY, +) SPOOF_ATTRIBUTES_DEFAULTS = { 'y_parity': DEFAULT_SPOOF_Y_PARITY, diff --git a/eth/_utils/state.py b/eth/_utils/state.py index 26e5fd2455..71b906c16e 100644 --- a/eth/_utils/state.py +++ b/eth/_utils/state.py @@ -6,7 +6,9 @@ AccountDiff, AccountState, ) -from eth.vm.state import BaseState +from eth.vm.state import ( + BaseState, +) @to_tuple diff --git a/eth/_utils/transactions.py b/eth/_utils/transactions.py index 3b8ee67706..db683e0d09 100644 --- a/eth/_utils/transactions.py +++ b/eth/_utils/transactions.py @@ -1,18 +1,23 @@ -from typing import NamedTuple - -import rlp +from typing import ( + NamedTuple, +) -from eth_keys import keys -from eth_keys import datatypes +from eth_keys import ( + datatypes, + keys, +) from eth_keys.exceptions import ( BadSignature, ) - from eth_utils import ( - int_to_big_endian, ValidationError, + int_to_big_endian, ) +import rlp +from eth._utils.numeric import ( + is_even, +) from eth.abc import ( SignedTransactionAPI, UnsignedTransactionAPI, @@ -20,16 +25,13 @@ from eth.constants import ( CREATE_CONTRACT_ADDRESS, ) +from eth.rlp.transactions import ( + BaseTransaction, +) from eth.typing import ( - Address, VRS, + Address, ) -from eth._utils.numeric import ( - is_even, -) - -from eth.rlp.transactions import BaseTransaction - EIP155_CHAIN_ID_OFFSET = 35 # Add this offset to y_parity to get "v" for legacy transactions, from Frontier diff --git a/eth/_utils/version.py b/eth/_utils/version.py index 1077df56f7..254c589f7c 100644 --- a/eth/_utils/version.py +++ b/eth/_utils/version.py @@ -1,6 +1,8 @@ import sys -from eth import __version__ +from eth import ( + __version__, +) def construct_evm_runtime_identifier() -> str: diff --git a/eth/_warnings.py b/eth/_warnings.py index 366d25aa75..4f7b2688f3 100644 --- a/eth/_warnings.py +++ b/eth/_warnings.py @@ -1,5 +1,9 @@ -from contextlib import contextmanager -from typing import Iterator +from contextlib import ( + contextmanager, +) +from typing import ( + Iterator, +) import warnings diff --git a/eth/abc.py b/eth/abc.py index ea0071d6fc..b38f88100f 100644 --- a/eth/abc.py +++ b/eth/abc.py @@ -1,6 +1,6 @@ from abc import ( ABC, - abstractmethod + abstractmethod, ) from typing import ( Any, @@ -9,6 +9,7 @@ ContextManager, Dict, FrozenSet, + Hashable, Iterable, Iterator, List, @@ -20,36 +21,38 @@ Type, TypeVar, Union, - Hashable, ) -from eth_bloom import BloomFilter - +from eth_bloom import ( + BloomFilter, +) +from eth_keys.datatypes import ( + PrivateKey, +) from eth_typing import ( Address, BlockNumber, Hash32, ) - -from eth_utils import ExtendedDebugLogger - -from eth_keys.datatypes import PrivateKey +from eth_utils import ( + ExtendedDebugLogger, +) from eth.constants import ( BLANK_ROOT_HASH, ) - -from eth.exceptions import VMError +from eth.exceptions import ( + VMError, +) from eth.typing import ( + AccountState, BytesOrView, ChainGaps, - JournalDBCheckpoint, - AccountState, HeaderParams, + JournalDBCheckpoint, VMConfiguration, ) - T = TypeVar('T') # A decoded RLP object of unknown interpretation, with a maximum "depth" of 1. diff --git a/eth/chains/base.py b/eth/chains/base.py index 04673793b2..214aa5d8d0 100644 --- a/eth/chains/base.py +++ b/eth/chains/base.py @@ -1,3 +1,4 @@ +import logging import operator import random from typing import ( @@ -10,8 +11,6 @@ Type, ) -import logging - from eth_typing import ( Address, BlockNumber, @@ -25,32 +24,35 @@ sliding_window, ) -from eth._utils.db import ( - apply_state_dict, -) from eth._utils.datatypes import ( Configurable, ) +from eth._utils.db import ( + apply_state_dict, +) from eth._utils.rlp import ( validate_imported_block_unchanged, ) +from eth._warnings import ( + catch_and_ignore_import_warning, +) from eth.abc import ( - BlockAPI, - BlockAndMetaWitness, - MiningChainAPI, AtomicDatabaseAPI, + BlockAndMetaWitness, + BlockAPI, BlockHeaderAPI, BlockImportResult, BlockPersistResult, ChainAPI, ChainDatabaseAPI, + ComputationAPI, ConsensusContextAPI, - VirtualMachineAPI, + MiningChainAPI, ReceiptAPI, - ComputationAPI, - StateAPI, SignedTransactionAPI, + StateAPI, UnsignedTransactionAPI, + VirtualMachineAPI, WithdrawalAPI, ) from eth.consensus import ( @@ -60,14 +62,12 @@ EMPTY_UNCLE_HASH, MAX_UNCLE_DEPTH, ) - from eth.db.chain import ( ChainDB, ) from eth.db.header import ( HeaderDB, ) - from eth.estimators import ( get_gas_estimator, ) @@ -76,30 +76,28 @@ TransactionNotFound, VMNotFound, ) - from eth.rlp.headers import ( BlockHeader, ) - from eth.typing import ( AccountState, HeaderParams, StaticMethod, ) - from eth.validation import ( validate_block_number, validate_uint256, - validate_word, validate_vm_configuration, + validate_word, +) +from eth.vm.chain_context import ( + ChainContext, ) -from eth.vm.chain_context import ChainContext -from eth._warnings import catch_and_ignore_import_warning with catch_and_ignore_import_warning(): from eth_utils import ( - to_set, ValidationError, + to_set, ) from eth_utils.toolz import ( assoc, diff --git a/eth/chains/goerli/constants.py b/eth/chains/goerli/constants.py index 807096a9bb..f91a96e5c7 100644 --- a/eth/chains/goerli/constants.py +++ b/eth/chains/goerli/constants.py @@ -1,5 +1,6 @@ -from eth_typing import BlockNumber - +from eth_typing import ( + BlockNumber, +) GOERLI_CHAIN_ID = 5 diff --git a/eth/chains/header.py b/eth/chains/header.py index de8a5c416f..95a3985f82 100644 --- a/eth/chains/header.py +++ b/eth/chains/header.py @@ -1,7 +1,7 @@ from typing import ( - cast, Tuple, Type, + cast, ) from eth_typing import ( @@ -9,6 +9,9 @@ Hash32, ) +from eth._utils.datatypes import ( + Configurable, +) from eth.abc import ( AtomicDatabaseAPI, BlockHeaderAPI, @@ -21,9 +24,6 @@ from eth.db.header import ( HeaderDB, ) -from eth._utils.datatypes import ( - Configurable, -) class HeaderChain(Configurable, HeaderChainAPI): diff --git a/eth/chains/mainnet/constants.py b/eth/chains/mainnet/constants.py index 4a42c06c8e..a75d3c9b34 100644 --- a/eth/chains/mainnet/constants.py +++ b/eth/chains/mainnet/constants.py @@ -1,5 +1,6 @@ -from eth_typing import BlockNumber - +from eth_typing import ( + BlockNumber, +) # https://github.com/ethereum/EIPs/blob/master/EIPS/eip-155.md MAINNET_CHAIN_ID = 1 diff --git a/eth/chains/ropsten/constants.py b/eth/chains/ropsten/constants.py index 9fe0bbe456..67498c066c 100644 --- a/eth/chains/ropsten/constants.py +++ b/eth/chains/ropsten/constants.py @@ -1,5 +1,6 @@ -from eth_typing import BlockNumber - +from eth_typing import ( + BlockNumber, +) # https://github.com/ethereum/EIPs/blob/master/EIPS/eip-155.md ROPSTEN_CHAIN_ID = 3 diff --git a/eth/consensus/clique/_utils.py b/eth/consensus/clique/_utils.py index 4473401187..368bdf75f2 100644 --- a/eth/consensus/clique/_utils.py +++ b/eth/consensus/clique/_utils.py @@ -2,19 +2,25 @@ Iterable, ) -from eth_keys import keys -from eth_keys.datatypes import PrivateKey +from eth_keys import ( + keys, +) +from eth_keys.datatypes import ( + PrivateKey, +) from eth_typing import ( Address, Hash32, ) from eth_utils import ( + ValidationError, encode_hex, to_tuple, - ValidationError, ) -from eth._utils.headers import eth_now +from eth._utils.headers import ( + eth_now, +) from eth.abc import ( BlockHeaderAPI, ) diff --git a/eth/consensus/clique/clique.py b/eth/consensus/clique/clique.py index 5c6e640386..bee4c16acd 100644 --- a/eth/consensus/clique/clique.py +++ b/eth/consensus/clique/clique.py @@ -4,26 +4,25 @@ Sequence, ) -from eth.abc import ( - AtomicDatabaseAPI, - BlockHeaderAPI, - VirtualMachineAPI, - VirtualMachineModifierAPI, -) -from eth.db.chain import ChainDB - from eth_typing import ( Address, ) from eth_utils import ( + ValidationError, encode_hex, to_tuple, - ValidationError, ) from eth.abc import ( + AtomicDatabaseAPI, + BlockHeaderAPI, ConsensusAPI, ConsensusContextAPI, + VirtualMachineAPI, + VirtualMachineModifierAPI, +) +from eth.db.chain import ( + ChainDB, ) from eth.typing import ( HeaderParams, @@ -31,17 +30,19 @@ VMFork, ) +from ._utils import ( + get_block_signer, + is_in_turn, + validate_header_integrity, +) from .constants import ( EPOCH_LENGTH, ) from .datatypes import ( Snapshot, ) -from .snapshot_manager import SnapshotManager -from ._utils import ( - get_block_signer, - is_in_turn, - validate_header_integrity, +from .snapshot_manager import ( + SnapshotManager, ) diff --git a/eth/consensus/clique/constants.py b/eth/consensus/clique/constants.py index 474bde958c..44d7f1a886 100644 --- a/eth/consensus/clique/constants.py +++ b/eth/consensus/clique/constants.py @@ -1,4 +1,6 @@ -from eth_utils import decode_hex +from eth_utils import ( + decode_hex, +) ALLOWED_CLIQUE_DIFFICULTIES = {1, 2} diff --git a/eth/consensus/clique/datatypes.py b/eth/consensus/clique/datatypes.py index 554d1e0c03..d3b3955def 100644 --- a/eth/consensus/clique/datatypes.py +++ b/eth/consensus/clique/datatypes.py @@ -1,5 +1,5 @@ from enum import ( - Enum + Enum, ) from typing import ( Dict, @@ -11,7 +11,7 @@ from eth_typing import ( Address, - Hash32 + Hash32, ) from eth_utils import ( ValidationError, @@ -19,7 +19,7 @@ from .constants import ( NONCE_AUTH, - NONCE_DROP + NONCE_DROP, ) diff --git a/eth/consensus/clique/encoding.py b/eth/consensus/clique/encoding.py index a67faaf6ef..c8cb2bfb8d 100644 --- a/eth/consensus/clique/encoding.py +++ b/eth/consensus/clique/encoding.py @@ -1,4 +1,3 @@ -import rlp from typing import ( Tuple, ) @@ -6,16 +5,17 @@ from eth_typing import ( Address, ) +import rlp -from eth.rlp.sedes import ( - uint256, -) from eth.consensus.clique.datatypes import ( Snapshot, Tally, Vote, VoteAction, ) +from eth.rlp.sedes import ( + uint256, +) ADDRESS_TALLY_SEDES = rlp.sedes.List((rlp.sedes.binary, rlp.sedes.binary)) VOTE_SEDES = rlp.sedes.List( diff --git a/eth/consensus/clique/exceptions.py b/eth/consensus/clique/exceptions.py index 843a65cdee..fcd90a8e18 100644 --- a/eth/consensus/clique/exceptions.py +++ b/eth/consensus/clique/exceptions.py @@ -1,4 +1,6 @@ -from eth.exceptions import PyEVMError +from eth.exceptions import ( + PyEVMError, +) class SnapshotNotFound(PyEVMError): diff --git a/eth/consensus/clique/snapshot_manager.py b/eth/consensus/clique/snapshot_manager.py index cb66d83a4e..434fd572a2 100644 --- a/eth/consensus/clique/snapshot_manager.py +++ b/eth/consensus/clique/snapshot_manager.py @@ -1,12 +1,5 @@ -import lru -from typing import Iterable - -from eth.abc import ( - BlockHeaderAPI, - ChainDatabaseAPI, -) -from eth.exceptions import ( - HeaderNotFound, +from typing import ( + Iterable, ) from eth_typing import ( @@ -14,17 +7,24 @@ Hash32, ) from eth_utils import ( + ValidationError, encode_hex, get_extended_debug_logger, - ValidationError, ) +import lru -from .encoding import ( - decode_snapshot, - encode_snapshot, +from eth.abc import ( + BlockHeaderAPI, + ChainDatabaseAPI, ) -from .exceptions import ( - SnapshotNotFound, +from eth.exceptions import ( + HeaderNotFound, +) + +from ._utils import ( + get_block_signer, + get_signers_at_checkpoint, + is_checkpoint, ) from .constants import ( IN_MEMORY_SNAPSHOTS, @@ -38,11 +38,12 @@ Vote, VoteAction, ) - -from ._utils import ( - get_signers_at_checkpoint, - get_block_signer, - is_checkpoint, +from .encoding import ( + decode_snapshot, + encode_snapshot, +) +from .exceptions import ( + SnapshotNotFound, ) diff --git a/eth/consensus/noproof.py b/eth/consensus/noproof.py index 06fb9e3870..40a174a984 100644 --- a/eth/consensus/noproof.py +++ b/eth/consensus/noproof.py @@ -1,6 +1,7 @@ from typing import ( Iterable, ) + from eth.abc import ( AtomicDatabaseAPI, BlockHeaderAPI, diff --git a/eth/consensus/pos.py b/eth/consensus/pos.py index 12b1fcd3ad..c38183fdf5 100644 --- a/eth/consensus/pos.py +++ b/eth/consensus/pos.py @@ -1,6 +1,7 @@ from typing import ( Iterable, ) + from eth.abc import ( AtomicDatabaseAPI, BlockHeaderAPI, diff --git a/eth/consensus/pow.py b/eth/consensus/pow.py index bf5228f6f0..7b636a65f8 100644 --- a/eth/consensus/pow.py +++ b/eth/consensus/pow.py @@ -1,29 +1,29 @@ -from collections import OrderedDict +from collections import ( + OrderedDict, +) from typing import ( Iterable, Tuple, ) +from eth_hash.auto import ( + keccak, +) from eth_typing import ( Address, Hash32, ) - from eth_utils import ( - big_endian_to_int, ValidationError, + big_endian_to_int, encode_hex, ) - -from eth_hash.auto import keccak - from pyethash import ( EPOCH_LENGTH, hashimoto_light, mkcache_bytes, ) - from eth.abc import ( AtomicDatabaseAPI, BlockHeaderAPI, @@ -34,7 +34,6 @@ validate_lte, ) - # Type annotation here is to ensure we don't accidentally use strings instead of bytes. cache_by_epoch: 'OrderedDict[int, bytearray]' = OrderedDict() CACHE_MAX_ITEMS = 10 diff --git a/eth/constants.py b/eth/constants.py index 762a46353d..f5262943c2 100644 --- a/eth/constants.py +++ b/eth/constants.py @@ -1,16 +1,22 @@ +from typing import ( + List, + Optional, +) + from eth_typing import ( Address, BlockNumber, Hash32, ) -from typing import ( - List, - Optional, + +from eth._warnings import ( + catch_and_ignore_import_warning, ) -from eth._warnings import catch_and_ignore_import_warning with catch_and_ignore_import_warning(): - from eth_utils import denoms + from eth_utils import ( + denoms, + ) ANY = 'any' diff --git a/eth/db/accesslog.py b/eth/db/accesslog.py index c4f0d84caf..074c50fe6c 100644 --- a/eth/db/accesslog.py +++ b/eth/db/accesslog.py @@ -1,22 +1,24 @@ -from contextlib import contextmanager +from contextlib import ( + contextmanager, +) import logging from typing import ( - Iterator, FrozenSet, + Iterator, Set, ) from eth.abc import ( - AtomicWriteBatchAPI, AtomicDatabaseAPI, + AtomicWriteBatchAPI, DatabaseAPI, ) -from eth.db.backends.base import ( - BaseDB, -) from eth.db.atomic import ( BaseAtomicDB, ) +from eth.db.backends.base import ( + BaseDB, +) class KeyAccessLoggerDB(BaseDB): diff --git a/eth/db/account.py b/eth/db/account.py index 5ada5c89be..084bb1ea0e 100644 --- a/eth/db/account.py +++ b/eth/db/account.py @@ -1,26 +1,29 @@ -from lru import LRU from typing import ( - cast, Dict, Iterable, Set, Tuple, + cast, ) -from eth_hash.auto import keccak +from eth_hash.auto import ( + keccak, +) from eth_typing import ( Address, - Hash32 + Hash32, ) - from eth_utils import ( + ValidationError, encode_hex, get_extended_debug_logger, int_to_big_endian, to_checksum_address, to_dict, to_tuple, - ValidationError, +) +from lru import ( + LRU, ) import rlp from trie import ( @@ -43,6 +46,9 @@ KeyAccessLoggerAtomicDB, KeyAccessLoggerDB, ) +from eth.db.backends.memory import ( + MemoryDB, +) from eth.db.batch import ( BatchDB, ) @@ -55,9 +61,6 @@ from eth.db.journal import ( JournalDB, ) -from eth.db.backends.memory import ( - MemoryDB, -) from eth.db.storage import ( AccountStorageDB, ) @@ -65,23 +68,25 @@ AccountQueryTracker, MetaWitness, ) -from eth.typing import ( - JournalDBCheckpoint, -) -from eth.vm.interrupt import ( - MissingAccountTrieNode, - MissingBytecode, -) from eth.rlp.accounts import ( Account, ) +from eth.typing import ( + JournalDBCheckpoint, +) from eth.validation import ( + validate_canonical_address, validate_is_bytes, validate_uint256, - validate_canonical_address, +) +from eth.vm.interrupt import ( + MissingAccountTrieNode, + MissingBytecode, ) -from .hash_trie import HashTrie +from .hash_trie import ( + HashTrie, +) IS_PRESENT_VALUE = b'' diff --git a/eth/db/atomic.py b/eth/db/atomic.py index 4bfe8de9f0..70df739afa 100644 --- a/eth/db/atomic.py +++ b/eth/db/atomic.py @@ -1,4 +1,6 @@ -from contextlib import contextmanager +from contextlib import ( + contextmanager, +) import logging from typing import ( Iterator, @@ -12,14 +14,18 @@ AtomicWriteBatchAPI, DatabaseAPI, ) - +from eth.db.backends.base import ( + BaseAtomicDB, + BaseDB, +) +from eth.db.backends.memory import ( + MemoryDB, +) from eth.db.diff import ( DBDiff, DBDiffTracker, DiffMissingError, ) -from eth.db.backends.base import BaseAtomicDB, BaseDB -from eth.db.backends.memory import MemoryDB class AtomicDB(BaseAtomicDB): diff --git a/eth/db/backends/level.py b/eth/db/backends/level.py index fb5763fed9..0ac6eef425 100644 --- a/eth/db/backends/level.py +++ b/eth/db/backends/level.py @@ -1,13 +1,22 @@ -from contextlib import contextmanager +from contextlib import ( + contextmanager, +) import logging -from pathlib import Path +from pathlib import ( + Path, +) from typing import ( - Iterator, TYPE_CHECKING, + Iterator, ) -from eth_utils import ValidationError +from eth_utils import ( + ValidationError, +) +from eth._warnings import ( + catch_and_ignore_import_warning, +) from eth.abc import ( AtomicWriteBatchAPI, DatabaseAPI, @@ -16,13 +25,12 @@ DBDiffTracker, DiffMissingError, ) + from .base import ( BaseAtomicDB, BaseDB, ) -from eth._warnings import catch_and_ignore_import_warning - if TYPE_CHECKING: with catch_and_ignore_import_warning(): import plyvel # noqa: F401 diff --git a/eth/db/batch.py b/eth/db/batch.py index a9835812e8..aee439caf3 100644 --- a/eth/db/batch.py +++ b/eth/db/batch.py @@ -4,13 +4,17 @@ ValidationError, ) -from eth.abc import DatabaseAPI +from eth.abc import ( + DatabaseAPI, +) +from eth.db.backends.base import ( + BaseDB, +) from eth.db.diff import ( DBDiff, DBDiffTracker, DiffMissingError, ) -from eth.db.backends.base import BaseDB class BatchDB(BaseDB): diff --git a/eth/db/cache.py b/eth/db/cache.py index a4dba2ae36..e9967dbfb8 100644 --- a/eth/db/cache.py +++ b/eth/db/cache.py @@ -1,7 +1,13 @@ -from lru import LRU +from lru import ( + LRU, +) -from eth.abc import DatabaseAPI -from eth.db.backends.base import BaseDB +from eth.abc import ( + DatabaseAPI, +) +from eth.db.backends.base import ( + BaseDB, +) class CacheDB(BaseDB): diff --git a/eth/db/chain.py b/eth/db/chain.py index 6db784b90b..a1aca85505 100644 --- a/eth/db/chain.py +++ b/eth/db/chain.py @@ -1,6 +1,5 @@ import functools import itertools - from typing import ( Dict, Iterable, @@ -10,28 +9,29 @@ cast, ) -from eth.vm.forks.shanghai.withdrawals import ( - Withdrawal, +from eth_hash.auto import ( + keccak, ) from eth_typing import ( BlockNumber, - Hash32 + Hash32, ) from eth_utils import ( encode_hex, ) - -from eth_hash.auto import keccak from trie.exceptions import ( MissingTrieNode, ) +from eth._warnings import ( + catch_and_ignore_import_warning, +) from eth.abc import ( + AtomicDatabaseAPI, BlockAPI, BlockHeaderAPI, ChainDatabaseAPI, DatabaseAPI, - AtomicDatabaseAPI, ReceiptAPI, ReceiptDecoderAPI, SignedTransactionAPI, @@ -43,37 +43,52 @@ GENESIS_PARENT_HASH, ) from eth.db.chain_gaps import ( - fill_gap, + GENESIS_CHAIN_GAPS, GapChange, GapInfo, - GENESIS_CHAIN_GAPS, + fill_gap, is_block_number_in_gap, reopen_gap, ) -from eth.db.trie import make_trie_root_and_nodes +from eth.db.header import ( + HeaderDB, +) +from eth.db.schema import ( + SchemaV1, +) +from eth.db.trie import ( + make_trie_root_and_nodes, +) from eth.exceptions import ( HeaderNotFound, ReceiptNotFound, TransactionNotFound, ) -from eth.db.header import HeaderDB -from eth.db.schema import SchemaV1 -from eth.rlp.sedes import chain_gaps -from eth.typing import ChainGaps +from eth.rlp.sedes import ( + chain_gaps, +) +from eth.typing import ( + ChainGaps, +) from eth.validation import ( validate_word, ) -from eth.vm.header import HeaderSedes -from eth._warnings import catch_and_ignore_import_warning +from eth.vm.forks.shanghai.withdrawals import ( + Withdrawal, +) +from eth.vm.header import ( + HeaderSedes, +) + with catch_and_ignore_import_warning(): + from eth_utils import ( + ValidationError, + to_tuple, + ) import rlp from trie import ( HexaryTrie, ) - from eth_utils import ( - to_tuple, - ValidationError, - ) class BlockDataKey(rlp.Serializable): diff --git a/eth/db/chain_gaps.py b/eth/db/chain_gaps.py index 4ab125d11c..93c0423048 100644 --- a/eth/db/chain_gaps.py +++ b/eth/db/chain_gaps.py @@ -1,14 +1,24 @@ import enum -from typing import Iterable, Tuple +from typing import ( + Iterable, + Tuple, +) -from eth_typing import BlockNumber +from eth_typing import ( + BlockNumber, +) from eth_utils import ( ValidationError, to_tuple, ) -from eth.exceptions import GapTrackingCorrupted -from eth.typing import BlockRange, ChainGaps +from eth.exceptions import ( + GapTrackingCorrupted, +) +from eth.typing import ( + BlockRange, + ChainGaps, +) class GapChange(enum.Enum): diff --git a/eth/db/diff.py b/eth/db/diff.py index d94553f62a..060437789c 100644 --- a/eth/db/diff.py +++ b/eth/db/diff.py @@ -3,12 +3,12 @@ MutableMapping, ) from typing import ( - cast, + TYPE_CHECKING, Dict, Iterable, - Union, Tuple, - TYPE_CHECKING, + Union, + cast, ) from eth_utils import ( @@ -16,8 +16,12 @@ to_tuple, ) -from eth.abc import DatabaseAPI -from eth.vm.interrupt import EVMMissingData +from eth.abc import ( + DatabaseAPI, +) +from eth.vm.interrupt import ( + EVMMissingData, +) if TYPE_CHECKING: ABC_Mutable_Mapping = MutableMapping[bytes, Union[bytes, 'MissingReason']] diff --git a/eth/db/hash_trie.py b/eth/db/hash_trie.py index 7b94c79530..6f218d56e0 100644 --- a/eth/db/hash_trie.py +++ b/eth/db/hash_trie.py @@ -1,11 +1,15 @@ import contextlib from typing import ( - cast, Iterator, + cast, ) -from eth_hash.auto import keccak -from trie import HexaryTrie +from eth_hash.auto import ( + keccak, +) +from trie import ( + HexaryTrie, +) from eth.db.keymap import ( KeyMapDB, diff --git a/eth/db/header.py b/eth/db/header.py index 862dba1a75..e9c72cc26e 100644 --- a/eth/db/header.py +++ b/eth/db/header.py @@ -1,29 +1,26 @@ import functools from typing import ( - cast, Iterable, Sequence, Tuple, + cast, ) -import rlp - -from eth_utils.toolz import ( - concat, - first, - sliding_window, +from eth_typing import ( + BlockNumber, + Hash32, ) - from eth_utils import ( + ValidationError, encode_hex, to_tuple, - ValidationError, ) - -from eth_typing import ( - Hash32, - BlockNumber, +from eth_utils.toolz import ( + concat, + first, + sliding_window, ) +import rlp from eth.abc import ( AtomicDatabaseAPI, @@ -35,27 +32,35 @@ GENESIS_PARENT_HASH, ) from eth.db.chain_gaps import ( - GapChange, - GapInfo, GAP_WRITES, GENESIS_CHAIN_GAPS, + GapChange, + GapInfo, fill_gap, reopen_gap, ) +from eth.db.schema import ( + SchemaV1, +) from eth.exceptions import ( CanonicalHeadNotFound, CheckpointsMustBeCanonical, HeaderNotFound, ParentNotFound, ) -from eth.db.schema import SchemaV1 -from eth.rlp.sedes import chain_gaps -from eth.typing import ChainGaps +from eth.rlp.sedes import ( + chain_gaps, +) +from eth.typing import ( + ChainGaps, +) from eth.validation import ( validate_block_number, validate_word, ) -from eth.vm.header import HeaderSedes +from eth.vm.header import ( + HeaderSedes, +) class HeaderDB(HeaderDatabaseAPI): diff --git a/eth/db/journal.py b/eth/db/journal.py index 033c079170..5b0e33a8db 100644 --- a/eth/db/journal.py +++ b/eth/db/journal.py @@ -2,21 +2,37 @@ from itertools import ( count, ) -from typing import Callable, cast, Dict, List, Set, Union +from typing import ( + Callable, + Dict, + List, + Set, + Union, + cast, +) +from eth_utils import ( + ValidationError, +) from eth_utils.toolz import ( first, nth, ) -from eth_utils import ( - ValidationError, -) -from eth.abc import DatabaseAPI -from eth.typing import JournalDBCheckpoint +from eth.abc import ( + DatabaseAPI, +) +from eth.typing import ( + JournalDBCheckpoint, +) -from .backends.base import BaseDB -from .diff import DBDiff, DBDiffTracker +from .backends.base import ( + BaseDB, +) +from .diff import ( + DBDiff, + DBDiffTracker, +) class DeletedEntry: diff --git a/eth/db/keymap.py b/eth/db/keymap.py index e65d1bcd2a..9481522dfd 100644 --- a/eth/db/keymap.py +++ b/eth/db/keymap.py @@ -1,13 +1,16 @@ from abc import ( abstractmethod, ) - from typing import ( Any, ) -from eth.abc import DatabaseAPI -from eth.db.backends.base import BaseDB +from eth.abc import ( + DatabaseAPI, +) +from eth.db.backends.base import ( + BaseDB, +) class KeyMapDB(BaseDB): diff --git a/eth/db/schema.py b/eth/db/schema.py index 760d763b4a..6abdeb1fa8 100644 --- a/eth/db/schema.py +++ b/eth/db/schema.py @@ -3,7 +3,9 @@ Hash32, ) -from eth.abc import SchemaAPI +from eth.abc import ( + SchemaAPI, +) class SchemaV1(SchemaAPI): diff --git a/eth/db/slow_journal.py b/eth/db/slow_journal.py index 4101dea216..5585e92d4a 100644 --- a/eth/db/slow_journal.py +++ b/eth/db/slow_journal.py @@ -1,19 +1,31 @@ import collections -from typing import cast, Dict, Set, Union +from typing import ( + Dict, + Set, + Union, + cast, +) import uuid +from eth_utils import ( + ValidationError, +) from eth_utils.toolz import ( first, merge, nth, ) -from eth_utils import ( - ValidationError, -) -from eth.abc import DatabaseAPI -from eth.db.backends.base import BaseDB -from eth.db.diff import DBDiff, DBDiffTracker +from eth.abc import ( + DatabaseAPI, +) +from eth.db.backends.base import ( + BaseDB, +) +from eth.db.diff import ( + DBDiff, + DBDiffTracker, +) class DeletedEntry: diff --git a/eth/db/storage.py b/eth/db/storage.py index e3c87bb9ce..ade294a723 100644 --- a/eth/db/storage.py +++ b/eth/db/storage.py @@ -5,7 +5,9 @@ Set, ) -from eth_hash.auto import keccak +from eth_hash.auto import ( + keccak, +) from eth_typing import ( Address, Hash32, @@ -50,12 +52,12 @@ from eth.db.journal import ( JournalDB, ) -from eth.vm.interrupt import ( - MissingStorageTrieNode, -) from eth.typing import ( JournalDBCheckpoint, ) +from eth.vm.interrupt import ( + MissingStorageTrieNode, +) class PendingWrites(NamedTuple): diff --git a/eth/db/trie.py b/eth/db/trie.py index f529a5b848..e637094930 100644 --- a/eth/db/trie.py +++ b/eth/db/trie.py @@ -1,13 +1,19 @@ import functools -from typing import Dict, Sequence, Tuple, Union +from typing import ( + Dict, + Sequence, + Tuple, + Union, +) +from eth_typing import ( + Hash32, +) import rlp from trie import ( HexaryTrie, ) -from eth_typing import Hash32 - from eth.abc import ( ReceiptAPI, SignedTransactionAPI, diff --git a/eth/estimators/gas.py b/eth/estimators/gas.py index b2b0481e71..2a27d2e962 100644 --- a/eth/estimators/gas.py +++ b/eth/estimators/gas.py @@ -1,14 +1,22 @@ -from typing import cast, Optional - -from eth_utils.toolz import curry +from typing import ( + Optional, + cast, +) -from eth.exceptions import VMError +from eth_utils.toolz import ( + curry, +) from eth.abc import ( SignedTransactionAPI, StateAPI, ) -from eth.vm.spoof import SpoofTransaction +from eth.exceptions import ( + VMError, +) +from eth.vm.spoof import ( + SpoofTransaction, +) def _get_computation_error(state: StateAPI, transaction: SignedTransactionAPI) -> Optional[VMError]: diff --git a/eth/exceptions.py b/eth/exceptions.py index 10b7e51870..ca207c85ca 100644 --- a/eth/exceptions.py +++ b/eth/exceptions.py @@ -1,4 +1,6 @@ -from eth_typing import Hash32 +from eth_typing import ( + Hash32, +) class PyEVMError(Exception): diff --git a/eth/precompiles/blake2.py b/eth/precompiles/blake2.py index 22c9a9accd..859a45638f 100644 --- a/eth/precompiles/blake2.py +++ b/eth/precompiles/blake2.py @@ -2,7 +2,9 @@ ValidationError, ) -from eth._utils.blake2.coders import extract_blake2b_parameters +from eth._utils.blake2.coders import ( + extract_blake2b_parameters, +) from eth.exceptions import ( VMError, ) @@ -11,9 +13,13 @@ ) try: - from blake2b import compress as blake2b_compress + from blake2b import ( + compress as blake2b_compress, + ) except ImportError: - from eth._utils.blake2.compression import blake2b_compress + from eth._utils.blake2.compression import ( + blake2b_compress, + ) GAS_COST_PER_ROUND = 1 diff --git a/eth/precompiles/ecadd.py b/eth/precompiles/ecadd.py index c17331e0df..aa54066288 100644 --- a/eth/precompiles/ecadd.py +++ b/eth/precompiles/ecadd.py @@ -1,7 +1,5 @@ -from typing import Tuple - -from py_ecc import ( - optimized_bn128 as bn128, +from typing import ( + Tuple, ) from eth_utils import ( @@ -12,11 +10,12 @@ from eth_utils.toolz import ( curry, ) +from py_ecc import ( + optimized_bn128 as bn128, +) -from eth import constants - -from eth.exceptions import ( - VMError, +from eth import ( + constants, ) from eth._utils.bn128 import ( validate_point, @@ -25,7 +24,9 @@ pad32, pad32r, ) - +from eth.exceptions import ( + VMError, +) from eth.vm.computation import ( BaseComputation, ) diff --git a/eth/precompiles/ecmul.py b/eth/precompiles/ecmul.py index aaf0ef9d52..787f6493e4 100644 --- a/eth/precompiles/ecmul.py +++ b/eth/precompiles/ecmul.py @@ -1,22 +1,21 @@ -from typing import Tuple - -from py_ecc import ( - optimized_bn128 as bn128, +from typing import ( + Tuple, ) from eth_utils import ( + ValidationError, big_endian_to_int, int_to_big_endian, - ValidationError, ) from eth_utils.toolz import ( curry, ) +from py_ecc import ( + optimized_bn128 as bn128, +) -from eth import constants - -from eth.exceptions import ( - VMError, +from eth import ( + constants, ) from eth._utils.bn128 import ( validate_point, @@ -25,7 +24,9 @@ pad32, pad32r, ) - +from eth.exceptions import ( + VMError, +) from eth.vm.computation import ( BaseComputation, ) diff --git a/eth/precompiles/ecpairing.py b/eth/precompiles/ecpairing.py index 6d435e6562..dc0a13daa6 100644 --- a/eth/precompiles/ecpairing.py +++ b/eth/precompiles/ecpairing.py @@ -1,8 +1,10 @@ -from typing import Tuple +from typing import ( + Tuple, +) from eth_utils import ( - big_endian_to_int, ValidationError, + big_endian_to_int, ) from eth_utils.toolz import ( curry, @@ -12,29 +14,26 @@ optimized_bn128 as bn128, ) -from eth import constants - -from eth.exceptions import ( - VMError, +from eth import ( + constants, ) - -from eth.typing import ( - BytesOrView, -) - from eth._utils.bn128 import ( - validate_point, FQP_point_to_FQ2_point, + validate_point, ) from eth._utils.padding import ( pad32, ) - +from eth.exceptions import ( + VMError, +) +from eth.typing import ( + BytesOrView, +) from eth.vm.computation import ( BaseComputation, ) - ZERO = bn128.Z2 EXPONENT = bn128.FQ12.one() diff --git a/eth/precompiles/ecrecover.py b/eth/precompiles/ecrecover.py index 4774d58133..ecd70fbeae 100644 --- a/eth/precompiles/ecrecover.py +++ b/eth/precompiles/ecrecover.py @@ -1,23 +1,24 @@ -from eth_keys import keys +from eth_keys import ( + keys, +) from eth_keys.exceptions import ( BadSignature, ) - from eth_utils import ( - big_endian_to_int, ValidationError, + big_endian_to_int, ) -from eth import constants - +from eth import ( + constants, +) from eth._utils.padding import ( pad32, pad32r, ) - from eth.validation import ( - validate_lt_secpk1n, validate_gte, + validate_lt_secpk1n, validate_lte, ) from eth.vm.computation import ( diff --git a/eth/precompiles/identity.py b/eth/precompiles/identity.py index f45c085cfb..7ebbfbcdd2 100644 --- a/eth/precompiles/identity.py +++ b/eth/precompiles/identity.py @@ -1,8 +1,9 @@ -from eth import constants +from eth import ( + constants, +) from eth._utils.numeric import ( ceil32, ) - from eth.vm.computation import ( BaseComputation, ) diff --git a/eth/precompiles/modexp.py b/eth/precompiles/modexp.py index d1f4942789..fddd2ab047 100644 --- a/eth/precompiles/modexp.py +++ b/eth/precompiles/modexp.py @@ -11,17 +11,17 @@ curry, ) -from eth import constants - +from eth import ( + constants, +) from eth._utils.numeric import ( get_highest_bit_index, ) from eth._utils.padding import ( pad32r, - zpad_right, zpad_left, + zpad_right, ) - from eth.vm.computation import ( BaseComputation, ) diff --git a/eth/precompiles/ripemd160.py b/eth/precompiles/ripemd160.py index 603167d03b..d713d95695 100644 --- a/eth/precompiles/ripemd160.py +++ b/eth/precompiles/ripemd160.py @@ -1,7 +1,8 @@ import hashlib -from eth import constants - +from eth import ( + constants, +) from eth._utils.numeric import ( ceil32, ) diff --git a/eth/precompiles/sha256.py b/eth/precompiles/sha256.py index 68231d204a..22835218b5 100644 --- a/eth/precompiles/sha256.py +++ b/eth/precompiles/sha256.py @@ -1,11 +1,11 @@ import hashlib -from eth import constants - +from eth import ( + constants, +) from eth._utils.numeric import ( ceil32, ) - from eth.vm.computation import ( BaseComputation, ) diff --git a/eth/rlp/accounts.py b/eth/rlp/accounts.py index ce4ae4658e..83e8efeeaf 100644 --- a/eth/rlp/accounts.py +++ b/eth/rlp/accounts.py @@ -1,21 +1,25 @@ +from typing import ( + Any, +) + import rlp from rlp.sedes import ( big_endian_int, ) -from eth.abc import AccountAPI +from eth.abc import ( + AccountAPI, +) from eth.constants import ( - EMPTY_SHA3, BLANK_ROOT_HASH, + EMPTY_SHA3, ) from .sedes import ( - trie_root, hash32, + trie_root, ) -from typing import Any - class Account(rlp.Serializable, AccountAPI): """ diff --git a/eth/rlp/headers.py b/eth/rlp/headers.py index 2add9f5387..fc5a8d6c47 100644 --- a/eth/rlp/headers.py +++ b/eth/rlp/headers.py @@ -4,24 +4,23 @@ overload, ) -import rlp -from rlp.sedes import ( - big_endian_int, - Binary, - binary, +from eth_hash.auto import ( + keccak, ) - from eth_typing import ( Address, BlockNumber, Hash32, ) - -from eth_hash.auto import keccak - from eth_utils import ( encode_hex, ) +import rlp +from rlp.sedes import ( + Binary, + big_endian_int, + binary, +) from eth._utils.headers import ( new_timestamp_from_parent, @@ -31,20 +30,22 @@ MiningHeaderAPI, ) from eth.constants import ( - ZERO_ADDRESS, - ZERO_HASH32, + BLANK_ROOT_HASH, EMPTY_UNCLE_HASH, GENESIS_NONCE, GENESIS_PARENT_HASH, - BLANK_ROOT_HASH, + ZERO_ADDRESS, + ZERO_HASH32, +) +from eth.typing import ( + HeaderParams, ) -from eth.typing import HeaderParams from .sedes import ( address, hash32, - uint256, trie_root, + uint256, ) diff --git a/eth/rlp/logs.py b/eth/rlp/logs.py index ea4f0db58f..649075aa6e 100644 --- a/eth/rlp/logs.py +++ b/eth/rlp/logs.py @@ -1,15 +1,16 @@ -from rlp.sedes import ( - CountableList, - binary, -) - from typing import ( Tuple, ) import rlp +from rlp.sedes import ( + CountableList, + binary, +) -from eth.abc import LogAPI +from eth.abc import ( + LogAPI, +) from .sedes import ( address, diff --git a/eth/rlp/receipts.py b/eth/rlp/receipts.py index 44af73f852..dcd1fd593a 100644 --- a/eth/rlp/receipts.py +++ b/eth/rlp/receipts.py @@ -1,11 +1,15 @@ import itertools -from typing import Iterable +from typing import ( + Iterable, +) -from eth_bloom import BloomFilter +from eth_bloom import ( + BloomFilter, +) import rlp from rlp.sedes import ( - big_endian_int, CountableList, + big_endian_int, binary, ) @@ -14,7 +18,9 @@ ReceiptBuilderAPI, ) -from .logs import Log +from .logs import ( + Log, +) from .sedes import ( uint256, ) diff --git a/eth/rlp/sedes.py b/eth/rlp/sedes.py index 333bfd039a..1aac26bd3d 100644 --- a/eth/rlp/sedes.py +++ b/eth/rlp/sedes.py @@ -4,7 +4,6 @@ Binary, ) - address = Binary.fixed_length(20, allow_empty=True) hash32 = Binary.fixed_length(32) uint32 = BigEndianInt(32) diff --git a/eth/rlp/transactions.py b/eth/rlp/transactions.py index 7781a7813a..d2540fd0e7 100644 --- a/eth/rlp/transactions.py +++ b/eth/rlp/transactions.py @@ -5,22 +5,24 @@ cast, ) -from cached_property import cached_property -import rlp -from rlp.sedes import ( - big_endian_int, - binary, +from cached_property import ( + cached_property, +) +from eth_hash.auto import ( + keccak, ) - from eth_typing import ( Address, Hash32, ) - -from eth_hash.auto import keccak from eth_utils import ( ValidationError, ) +import rlp +from rlp.sedes import ( + big_endian_int, + binary, +) from eth.abc import ( BaseTransactionAPI, @@ -32,7 +34,9 @@ UnsignedTransactionAPI, ) -from .sedes import address +from .sedes import ( + address, +) class BaseTransactionMethods(BaseTransactionAPI): diff --git a/eth/tools/_utils/deprecation.py b/eth/tools/_utils/deprecation.py index 44710a20e0..49960c7a4d 100644 --- a/eth/tools/_utils/deprecation.py +++ b/eth/tools/_utils/deprecation.py @@ -1,12 +1,11 @@ import functools -import warnings from typing import ( Any, Callable, TypeVar, cast, ) - +import warnings TFunc = TypeVar("TFunc", bound=Callable[..., Any]) diff --git a/eth/tools/_utils/git.py b/eth/tools/_utils/git.py index d45eb91340..a2e3a2a2c8 100644 --- a/eth/tools/_utils/git.py +++ b/eth/tools/_utils/git.py @@ -1,6 +1,8 @@ import subprocess -from eth_utils import to_text +from eth_utils import ( + to_text, +) def get_version_from_git() -> str: diff --git a/eth/tools/_utils/hashing.py b/eth/tools/_utils/hashing.py index 1dcacdb20b..8744e1a852 100644 --- a/eth/tools/_utils/hashing.py +++ b/eth/tools/_utils/hashing.py @@ -4,13 +4,17 @@ cast, ) -from eth_hash.auto import keccak +from eth_hash.auto import ( + keccak, +) from eth_typing import ( Hash32, ) import rlp -from eth.rlp.logs import Log +from eth.rlp.logs import ( + Log, +) def hash_log_entries(log_entries: Iterable[Tuple[bytes, Tuple[int, ...], bytes]]) -> Hash32: diff --git a/eth/tools/_utils/mappings.py b/eth/tools/_utils/mappings.py index 1a0483e25f..de449a3762 100644 --- a/eth/tools/_utils/mappings.py +++ b/eth/tools/_utils/mappings.py @@ -1,13 +1,16 @@ -from collections.abc import Mapping +from collections.abc import ( + Mapping, +) import itertools - from typing import ( Any, Dict, Sequence, ) -from eth_utils.toolz import merge_with +from eth_utils.toolz import ( + merge_with, +) def merge_if_dicts(values: Sequence[Dict[Any, Any]]) -> Any: diff --git a/eth/tools/_utils/normalization.py b/eth/tools/_utils/normalization.py index 27351a3437..04a8762b6e 100644 --- a/eth/tools/_utils/normalization.py +++ b/eth/tools/_utils/normalization.py @@ -4,7 +4,6 @@ Any, AnyStr, Callable, - cast, Dict, Iterable, List, @@ -12,28 +11,15 @@ Sequence, Tuple, Union, + cast, ) -from mypy_extensions import ( - TypedDict, -) - -from eth_utils.toolz import ( - assoc_in, - compose, - concat, - curry, - identity, - merge, -) -from eth_utils.toolz import curried - from eth_typing import ( Address, HexStr, ) - from eth_utils.curried import ( + ValidationError, apply_formatter_if, apply_formatter_to_array, apply_formatters_to_dict, @@ -49,18 +35,27 @@ to_bytes, to_canonical_address, to_dict, - ValidationError, +) +from eth_utils.toolz import ( + assoc_in, + compose, + concat, + curried, + curry, + identity, + merge, +) +from mypy_extensions import ( + TypedDict, ) from eth.constants import ( CREATE_CONTRACT_ADDRESS, ) - from eth.tools._utils.mappings import ( deep_merge, is_cleanly_mergable, ) - from eth.typing import ( AccountState, GeneralState, diff --git a/eth/tools/_utils/slow_code_stream.py b/eth/tools/_utils/slow_code_stream.py index 4547efdfd7..d459f6278c 100644 --- a/eth/tools/_utils/slow_code_stream.py +++ b/eth/tools/_utils/slow_code_stream.py @@ -3,13 +3,15 @@ import logging from typing import ( Iterator, - Set + Set, ) from eth.validation import ( validate_is_bytes, ) -from eth.vm import opcode_values +from eth.vm import ( + opcode_values, +) PUSH1, PUSH32, STOP = opcode_values.PUSH1, opcode_values.PUSH32, opcode_values.STOP diff --git a/eth/tools/_utils/vyper.py b/eth/tools/_utils/vyper.py index b1717e32fd..17e816fcb3 100644 --- a/eth/tools/_utils/vyper.py +++ b/eth/tools/_utils/vyper.py @@ -1,5 +1,4 @@ import functools - from typing import ( Any, Callable, @@ -10,10 +9,12 @@ try: from vyper.compile_lll import ( - compile_to_assembly, assembly_to_evm, + compile_to_assembly, + ) + from vyper.parser.parser_utils import ( + LLLnode, ) - from vyper.parser.parser_utils import LLLnode except ImportError: vyper_available = False else: diff --git a/eth/tools/builder/chain/builders.py b/eth/tools/builder/chain/builders.py index c3fa727a1f..f7540395b4 100644 --- a/eth/tools/builder/chain/builders.py +++ b/eth/tools/builder/chain/builders.py @@ -1,7 +1,6 @@ import functools import time from typing import ( - cast, Any, Callable, Dict, @@ -9,12 +8,7 @@ Tuple, Type, Union, -) - -from eth_utils.toolz import ( - curry, - merge, - pipe, + cast, ) from eth_typing import ( @@ -22,14 +16,20 @@ BlockNumber, Hash32, ) - from eth_utils import ( + ValidationError, to_dict, to_tuple, - ValidationError, +) +from eth_utils.toolz import ( + curry, + merge, + pipe, ) -from eth import constants +from eth import ( + constants, +) from eth.abc import ( AtomicDatabaseAPI, BlockAPI, @@ -37,47 +37,55 @@ MiningChainAPI, VirtualMachineAPI, ) -from eth.consensus.applier import ConsensusApplier -from eth.consensus.noproof import NoProofConsensus -from eth.db.atomic import AtomicDB +from eth.consensus.applier import ( + ConsensusApplier, +) +from eth.consensus.noproof import ( + NoProofConsensus, +) +from eth.db.atomic import ( + AtomicDB, +) from eth.db.backends.memory import ( MemoryDB, ) from eth.rlp.headers import ( HeaderParams, ) -from eth.tools.mining import POWMiningMixin from eth.tools._utils.mappings import ( deep_merge, ) from eth.tools._utils.normalization import ( normalize_state, ) +from eth.tools.mining import ( + POWMiningMixin, +) from eth.typing import ( AccountState, GeneralState, - VMFork, VMConfiguration, + VMFork, ) from eth.validation import ( validate_vm_configuration, ) from eth.vm.forks import ( - FrontierVM, - HomesteadVM, - TangerineWhistleVM, - SpuriousDragonVM, + ArrowGlacierVM, + BerlinVM, ByzantiumVM, ConstantinopleVM, - PetersburgVM, + FrontierVM, + GrayGlacierVM, + HomesteadVM, IstanbulVM, - MuirGlacierVM, - BerlinVM, LondonVM, - ArrowGlacierVM, - GrayGlacierVM, + MuirGlacierVM, ParisVM, + PetersburgVM, ShanghaiVM, + SpuriousDragonVM, + TangerineWhistleVM, ) diff --git a/eth/tools/db/atomic.py b/eth/tools/db/atomic.py index 7b3a2c5fc9..5ae0775ab3 100644 --- a/eth/tools/db/atomic.py +++ b/eth/tools/db/atomic.py @@ -1,8 +1,12 @@ import pytest -from eth_utils import ValidationError +from eth_utils import ( + ValidationError, +) -from eth.abc import AtomicDatabaseAPI +from eth.abc import ( + AtomicDatabaseAPI, +) class AtomicDatabaseBatchAPITestSuite: diff --git a/eth/tools/db/base.py b/eth/tools/db/base.py index f0d5011196..6cdc46ba64 100644 --- a/eth/tools/db/base.py +++ b/eth/tools/db/base.py @@ -1,6 +1,8 @@ import pytest -from eth.abc import DatabaseAPI +from eth.abc import ( + DatabaseAPI, +) class DatabaseAPITestSuite: diff --git a/eth/tools/factories/keys.py b/eth/tools/factories/keys.py index 4721cdb6ce..afd06727f5 100644 --- a/eth/tools/factories/keys.py +++ b/eth/tools/factories/keys.py @@ -1,14 +1,18 @@ import secrets + +from eth_keys import ( + keys, +) +from eth_utils import ( + int_to_big_endian, +) + try: import factory except ImportError: raise ImportError("The p2p.tools.factories module requires the `factory_boy` library.") -from eth_utils import ( - int_to_big_endian, -) -from eth_keys import keys def _mk_private_key_bytes() -> bytes: diff --git a/eth/tools/factories/transaction.py b/eth/tools/factories/transaction.py index 86651f6962..d5bdf0e3d0 100644 --- a/eth/tools/factories/transaction.py +++ b/eth/tools/factories/transaction.py @@ -1,4 +1,6 @@ -from eth_utils.toolz import curry +from eth_utils.toolz import ( + curry, +) from eth.vm.spoof import ( SpoofTransaction, diff --git a/eth/tools/fixtures/_utils.py b/eth/tools/fixtures/_utils.py index fe9e85e107..1410559775 100644 --- a/eth/tools/fixtures/_utils.py +++ b/eth/tools/fixtures/_utils.py @@ -1,14 +1,15 @@ import fnmatch import functools import os - from typing import ( Any, Callable, Iterable, ) -from eth_utils import to_tuple +from eth_utils import ( + to_tuple, +) @to_tuple diff --git a/eth/tools/fixtures/fillers/_utils.py b/eth/tools/fixtures/fillers/_utils.py index 7319c0e08d..1adb7ddbda 100644 --- a/eth/tools/fixtures/fillers/_utils.py +++ b/eth/tools/fixtures/fillers/_utils.py @@ -8,7 +8,9 @@ Type, ) -from eth_keys import keys +from eth_keys import ( + keys, +) from eth_typing import ( Address, ) @@ -22,8 +24,12 @@ from eth._utils.padding import ( pad32, ) -from eth.constants import BLANK_ROOT_HASH -from eth.db.atomic import AtomicDB +from eth.constants import ( + BLANK_ROOT_HASH, +) +from eth.db.atomic import ( + AtomicDB, +) from eth.typing import ( AccountState, TransactionDict, diff --git a/eth/tools/fixtures/fillers/common.py b/eth/tools/fixtures/fillers/common.py index 6581c54873..edd023c91f 100644 --- a/eth/tools/fixtures/fillers/common.py +++ b/eth/tools/fixtures/fillers/common.py @@ -10,35 +10,35 @@ Callable, Dict, ) + +from eth_utils import ( + apply_formatters_to_dict, + decode_hex, + to_canonical_address, +) from eth_utils.toolz import ( assoc, assoc_in, curry, merge, ) -from eth_utils import ( - apply_formatters_to_dict, - decode_hex, - to_canonical_address, -) -from eth.tools.fixtures.helpers import ( - get_test_name, +from eth.tools._utils.mappings import ( + deep_merge, ) from eth.tools._utils.normalization import ( normalize_environment, normalize_execution, + normalize_networks, normalize_state, normalize_transaction, - normalize_networks, -) -from eth.tools._utils.mappings import ( - deep_merge, ) from eth.tools._utils.vyper import ( compile_vyper_lll, ) - +from eth.tools.fixtures.helpers import ( + get_test_name, +) from eth.typing import ( GeneralState, TransactionDict, @@ -49,7 +49,6 @@ wrap_in_list, ) - # # Defaults # diff --git a/eth/tools/fixtures/fillers/formatters.py b/eth/tools/fixtures/fillers/formatters.py index d286496402..85797638f2 100644 --- a/eth/tools/fixtures/fillers/formatters.py +++ b/eth/tools/fixtures/fillers/formatters.py @@ -12,9 +12,9 @@ to_checksum_address, to_hex, ) - -from eth_utils.toolz import curried - +from eth_utils.toolz import ( + curried, +) environment_formatter = apply_formatters_to_dict({ "currentCoinbase": to_checksum_address, diff --git a/eth/tools/fixtures/fillers/main.py b/eth/tools/fixtures/fillers/main.py index 4fa9a3e6cf..0e9cac7ddd 100644 --- a/eth/tools/fixtures/fillers/main.py +++ b/eth/tools/fixtures/fillers/main.py @@ -8,18 +8,23 @@ merge, ) +from eth.tools._utils.git import ( + get_version_from_git, +) from eth.tools.fixtures.helpers import ( get_test_name, ) -from eth.tools._utils.git import get_version_from_git from .formatters import ( filled_state_test_formatter, filled_vm_test_formatter, ) -from .state import fill_state_test -from .vm import fill_vm_test - +from .state import ( + fill_state_test, +) +from .vm import ( + fill_vm_test, +) FILLED_WITH_TEMPLATE = "py-evm-{version}" diff --git a/eth/tools/fixtures/fillers/state.py b/eth/tools/fixtures/fillers/state.py index 36aa71cb54..649ce558fd 100644 --- a/eth/tools/fixtures/fillers/state.py +++ b/eth/tools/fixtures/fillers/state.py @@ -1,14 +1,18 @@ -from collections import defaultdict +from collections import ( + defaultdict, +) from typing import ( Any, Dict, List, ) -from eth_utils import encode_hex +from eth_utils import ( + encode_hex, +) -from eth.tools.fixtures.helpers import ( - get_test_name, +from eth.tools._utils.mappings import ( + deep_merge, ) from eth.tools._utils.normalization import ( normalize_environment, @@ -16,21 +20,38 @@ normalize_state, normalize_transaction_group, ) -from eth.tools._utils.mappings import deep_merge -from eth.vm.forks.byzantium.state import ByzantiumState -from eth.vm.forks.constantinople.state import ConstantinopleState -from eth.vm.forks.frontier.state import FrontierState -from eth.vm.forks.homestead.state import HomesteadState -from eth.vm.forks.istanbul.state import IstanbulState -from eth.vm.forks.petersburg.state import PetersburgState -from eth.vm.forks.spurious_dragon.state import SpuriousDragonState -from eth.vm.forks.tangerine_whistle.state import TangerineWhistleState +from eth.tools.fixtures.helpers import ( + get_test_name, +) +from eth.vm.forks.byzantium.state import ( + ByzantiumState, +) +from eth.vm.forks.constantinople.state import ( + ConstantinopleState, +) +from eth.vm.forks.frontier.state import ( + FrontierState, +) +from eth.vm.forks.homestead.state import ( + HomesteadState, +) +from eth.vm.forks.istanbul.state import ( + IstanbulState, +) +from eth.vm.forks.petersburg.state import ( + PetersburgState, +) +from eth.vm.forks.spurious_dragon.state import ( + SpuriousDragonState, +) +from eth.vm.forks.tangerine_whistle.state import ( + TangerineWhistleState, +) from ._utils import ( calc_state_root, ) - ALL_NETWORKS = [ "Frontier", "Homestead", diff --git a/eth/tools/fixtures/fillers/vm.py b/eth/tools/fixtures/fillers/vm.py index 609d906dc9..b6dec34605 100644 --- a/eth/tools/fixtures/fillers/vm.py +++ b/eth/tools/fixtures/fillers/vm.py @@ -6,8 +6,11 @@ Union, ) -from eth.tools.fixtures.helpers import ( - get_test_name, +from eth.tools._utils.hashing import ( + hash_log_entries, +) +from eth.tools._utils.mappings import ( + deep_merge, ) from eth.tools._utils.normalization import ( normalize_bytes, @@ -18,8 +21,9 @@ normalize_logs, normalize_state, ) -from eth.tools._utils.hashing import hash_log_entries -from eth.tools._utils.mappings import deep_merge +from eth.tools.fixtures.helpers import ( + get_test_name, +) def fill_vm_test( diff --git a/eth/tools/fixtures/generation.py b/eth/tools/fixtures/generation.py index fec792ac0e..5a57180f96 100644 --- a/eth/tools/fixtures/generation.py +++ b/eth/tools/fixtures/generation.py @@ -1,5 +1,4 @@ import hashlib - from typing import ( Any, Callable, diff --git a/eth/tools/fixtures/helpers.py b/eth/tools/fixtures/helpers.py index d12c84283c..5c948d253d 100644 --- a/eth/tools/fixtures/helpers.py +++ b/eth/tools/fixtures/helpers.py @@ -1,60 +1,61 @@ import os - -import rlp - from typing import ( - cast, Any, Dict, Iterable, Tuple, Type, + cast, ) +from eth_utils import ( + to_normalized_address, +) from eth_utils.toolz import ( assoc, first, ) +import rlp -from eth_utils import ( - to_normalized_address, +from eth import ( + MainnetChain, + constants, +) +from eth._utils.state import ( + diff_state, ) - -from eth import MainnetChain from eth.abc import ( BlockAPI, ChainAPI, StateAPI, VirtualMachineAPI, ) -from eth import constants -from eth.db.atomic import AtomicDB from eth.chains.mainnet import ( MainnetDAOValidatorVM, ) +from eth.db.atomic import ( + AtomicDB, +) from eth.tools.builder.chain import ( disable_pow_check, ) from eth.typing import ( AccountState, ) -from eth._utils.state import ( - diff_state, -) from eth.vm.forks import ( - PetersburgVM, - ConstantinopleVM, + BerlinVM, ByzantiumVM, - TangerineWhistleVM, + ConstantinopleVM, FrontierVM, + GrayGlacierVM, HomesteadVM as BaseHomesteadVM, - SpuriousDragonVM, IstanbulVM, - BerlinVM, LondonVM, - GrayGlacierVM, ParisVM, + PetersburgVM, ShanghaiVM, + SpuriousDragonVM, + TangerineWhistleVM, ) diff --git a/eth/tools/fixtures/loading.py b/eth/tools/fixtures/loading.py index 71bf3ac4a6..63b17ddce0 100644 --- a/eth/tools/fixtures/loading.py +++ b/eth/tools/fixtures/loading.py @@ -1,7 +1,6 @@ import functools import json import os - from typing import ( Any, Callable, @@ -10,13 +9,14 @@ Tuple, ) +from eth_utils import ( + to_tuple, +) from eth_utils.toolz import ( curry, identity, ) -from eth_utils import to_tuple - from ._utils import ( recursive_find_files, require_pytest, diff --git a/eth/tools/mining.py b/eth/tools/mining.py index c2aa7105ec..f85c3da0fe 100644 --- a/eth/tools/mining.py +++ b/eth/tools/mining.py @@ -1,6 +1,6 @@ from eth.abc import ( - BlockAPI, BlockAndMetaWitness, + BlockAPI, VirtualMachineAPI, ) from eth.consensus import ( diff --git a/eth/tools/rlp.py b/eth/tools/rlp.py index 5e81ad15da..1ad065cb14 100644 --- a/eth/tools/rlp.py +++ b/eth/tools/rlp.py @@ -1,13 +1,12 @@ from eth_utils import ( - replace_exceptions, ValidationError, + replace_exceptions, ) from eth._utils.rlp import ( validate_rlp_equal, ) - assert_imported_block_unchanged = replace_exceptions({ ValidationError: AssertionError, })(validate_rlp_equal(obj_a_name='provided block', obj_b_name='executed block')) diff --git a/eth/typing.py b/eth/typing.py index 5c575f5902..0a79b39abf 100644 --- a/eth/typing.py +++ b/eth/typing.py @@ -1,17 +1,17 @@ from typing import ( + TYPE_CHECKING, Any, Callable, Dict, Generic, Iterable, List, - Optional, NewType, + Optional, Sequence, Tuple, Type, TypeVar, - TYPE_CHECKING, Union, ) diff --git a/eth/validation.py b/eth/validation.py index f09fd5e8df..877da446fb 100644 --- a/eth/validation.py +++ b/eth/validation.py @@ -1,41 +1,40 @@ import functools - from typing import ( Any, - cast, Dict, Iterable, Sequence, Tuple, Type, Union, + cast, ) from eth_typing import ( Address, Hash32, ) - from eth_utils import ( - is_list_like, ValidationError, + is_list_like, +) +from eth_utils.toolz import ( + dicttoolz, + functoolz, + itertoolz, ) -from eth_utils.toolz import dicttoolz - -from eth_utils.toolz import functoolz - -from eth_utils.toolz import itertoolz from eth._utils.headers import ( compute_gas_limit_bounds, ) -from eth.abc import VirtualMachineAPI +from eth.abc import ( + VirtualMachineAPI, +) from eth.constants import ( SECPK1_N, - UINT_256_MAX, UINT_64_MAX, + UINT_256_MAX, ) - from eth.typing import ( BytesOrView, ) diff --git a/eth/vm/base.py b/eth/vm/base.py index d2fde2cfc6..e7f4826bf4 100644 --- a/eth/vm/base.py +++ b/eth/vm/base.py @@ -16,8 +16,12 @@ Union, ) -from cached_property import cached_property -from eth_hash.auto import keccak +from cached_property import ( + cached_property, +) +from eth_hash.auto import ( + keccak, +) from eth_typing import ( Address, Hash32, @@ -28,10 +32,17 @@ ) import rlp +from eth._utils.datatypes import ( + Configurable, +) +from eth._utils.db import ( + get_block_header_by_hash, + get_parent_header, +) from eth.abc import ( AtomicDatabaseAPI, - BlockAPI, BlockAndMetaWitness, + BlockAPI, BlockHeaderAPI, ChainContextAPI, ChainDatabaseAPI, @@ -56,7 +67,9 @@ MAX_PREV_HEADER_DEPTH, MAX_UNCLES, ) -from eth.db.trie import make_trie_root_and_nodes +from eth.db.trie import ( + make_trie_root_and_nodes, +) from eth.exceptions import ( HeaderNotFound, ) @@ -66,16 +79,9 @@ from eth.rlp.sedes import ( uint32, ) -from eth._utils.datatypes import ( - Configurable, -) -from eth._utils.db import ( - get_parent_header, - get_block_header_by_hash, -) from eth.validation import ( - validate_length_lte, validate_gas_limit, + validate_length_lte, ) from eth.vm.execution_context import ( ExecutionContext, diff --git a/eth/vm/chain_context.py b/eth/vm/chain_context.py index 2588b53cf2..4601129046 100644 --- a/eth/vm/chain_context.py +++ b/eth/vm/chain_context.py @@ -1,6 +1,10 @@ -from typing import Optional +from typing import ( + Optional, +) -from eth.abc import ChainContextAPI +from eth.abc import ( + ChainContextAPI, +) from eth.validation import ( validate_uint256, ) diff --git a/eth/vm/code_stream.py b/eth/vm/code_stream.py index fc90da43c6..3845a9342f 100644 --- a/eth/vm/code_stream.py +++ b/eth/vm/code_stream.py @@ -2,10 +2,12 @@ import logging from typing import ( Iterator, - Set + Set, ) -from eth.abc import CodeStreamAPI +from eth.abc import ( + CodeStreamAPI, +) from eth.validation import ( validate_is_bytes, ) diff --git a/eth/vm/computation.py b/eth/vm/computation.py index 30ebb29bbb..908e898211 100644 --- a/eth/vm/computation.py +++ b/eth/vm/computation.py @@ -1,5 +1,7 @@ import itertools -from types import TracebackType +from types import ( + TracebackType, +) from typing import ( Any, Callable, @@ -12,7 +14,9 @@ cast, ) -from cached_property import cached_property +from cached_property import ( + cached_property, +) from eth_typing import ( Address, ) @@ -21,14 +25,20 @@ get_extended_debug_logger, ) +from eth._utils.datatypes import ( + Configurable, +) +from eth._utils.numeric import ( + ceil32, +) from eth.abc import ( - MemoryAPI, - StackAPI, + CodeStreamAPI, + ComputationAPI, GasMeterAPI, + MemoryAPI, MessageAPI, OpcodeAPI, - CodeStreamAPI, - ComputationAPI, + StackAPI, StateAPI, TransactionContextAPI, ) @@ -43,12 +53,6 @@ from eth.typing import ( BytesOrView, ) -from eth._utils.datatypes import ( - Configurable, -) -from eth._utils.numeric import ( - ceil32, -) from eth.validation import ( validate_canonical_address, validate_is_bytes, diff --git a/eth/vm/execution_context.py b/eth/vm/execution_context.py index 85941f11ce..c68a189161 100644 --- a/eth/vm/execution_context.py +++ b/eth/vm/execution_context.py @@ -9,8 +9,12 @@ Hash32, ) -from eth.abc import ExecutionContextAPI -from eth._utils.generator import CachedIterable +from eth._utils.generator import ( + CachedIterable, +) +from eth.abc import ( + ExecutionContextAPI, +) class ExecutionContext(ExecutionContextAPI): diff --git a/eth/vm/forks/arrow_glacier/blocks.py b/eth/vm/forks/arrow_glacier/blocks.py index aaa042c9f0..e2eafe201b 100644 --- a/eth/vm/forks/arrow_glacier/blocks.py +++ b/eth/vm/forks/arrow_glacier/blocks.py @@ -1,18 +1,21 @@ -from abc import ABC -from typing import Type +from abc import ( + ABC, +) +from typing import ( + Type, +) -from eth.abc import TransactionBuilderAPI from eth_utils import ( encode_hex, ) - from rlp.sedes import ( CountableList, ) -from .transactions import ( - ArrowGlacierTransactionBuilder, +from eth.abc import ( + TransactionBuilderAPI, ) + from ..london import ( LondonBlock, ) @@ -21,6 +24,9 @@ LondonBlockHeader, LondonMiningHeader, ) +from .transactions import ( + ArrowGlacierTransactionBuilder, +) class ArrowGlacierMiningHeader(LondonMiningHeader, ABC): diff --git a/eth/vm/forks/arrow_glacier/computation.py b/eth/vm/forks/arrow_glacier/computation.py index 3779e0976a..0ac3cc4140 100644 --- a/eth/vm/forks/arrow_glacier/computation.py +++ b/eth/vm/forks/arrow_glacier/computation.py @@ -1,4 +1,6 @@ -from ..london.computation import LondonComputation +from ..london.computation import ( + LondonComputation, +) class ArrowGlacierComputation(LondonComputation): diff --git a/eth/vm/forks/arrow_glacier/headers.py b/eth/vm/forks/arrow_glacier/headers.py index ae99201444..0f5f9de3d8 100644 --- a/eth/vm/forks/arrow_glacier/headers.py +++ b/eth/vm/forks/arrow_glacier/headers.py @@ -1,20 +1,27 @@ -from typing import Any, Callable, Optional - -from toolz import curry +from typing import ( + Any, + Callable, + Optional, +) -from eth.abc import BlockHeaderAPI -from .blocks import ( - ArrowGlacierBlockHeader, +from toolz import ( + curry, ) -from eth.vm.forks.london.headers import ( - create_london_header_from_parent, + +from eth.abc import ( + BlockHeaderAPI, ) from eth.vm.forks.byzantium.headers import ( compute_difficulty, -) -from eth.vm.forks.byzantium.headers import ( configure_header, ) +from eth.vm.forks.london.headers import ( + create_london_header_from_parent, +) + +from .blocks import ( + ArrowGlacierBlockHeader, +) compute_arrow_glacier_difficulty = compute_difficulty(10_700_000) configure_arrow_glacier_header = configure_header(difficulty_fn=compute_arrow_glacier_difficulty) diff --git a/eth/vm/forks/arrow_glacier/state.py b/eth/vm/forks/arrow_glacier/state.py index 76882c3ff8..e1db23033c 100644 --- a/eth/vm/forks/arrow_glacier/state.py +++ b/eth/vm/forks/arrow_glacier/state.py @@ -1,9 +1,20 @@ -from typing import Type +from typing import ( + Type, +) -from eth.abc import TransactionExecutorAPI -from .computation import ArrowGlacierComputation -from ..london import LondonState -from ..london.state import LondonTransactionExecutor +from eth.abc import ( + TransactionExecutorAPI, +) + +from ..london import ( + LondonState, +) +from ..london.state import ( + LondonTransactionExecutor, +) +from .computation import ( + ArrowGlacierComputation, +) class ArrowGlacierTransactionExecutor(LondonTransactionExecutor): diff --git a/eth/vm/forks/arrow_glacier/transactions.py b/eth/vm/forks/arrow_glacier/transactions.py index b90b66202f..5f44eefe91 100644 --- a/eth/vm/forks/arrow_glacier/transactions.py +++ b/eth/vm/forks/arrow_glacier/transactions.py @@ -1,6 +1,10 @@ -from abc import ABC +from abc import ( + ABC, +) -from eth_keys.datatypes import PrivateKey +from eth_keys.datatypes import ( + PrivateKey, +) from eth._utils.transactions import ( create_transaction_signature, diff --git a/eth/vm/forks/berlin/blocks.py b/eth/vm/forks/berlin/blocks.py index 7e062e7a10..0e31e7b435 100644 --- a/eth/vm/forks/berlin/blocks.py +++ b/eth/vm/forks/berlin/blocks.py @@ -1,4 +1,6 @@ -from typing import Type +from typing import ( + Type, +) from rlp.sedes import ( CountableList, diff --git a/eth/vm/forks/berlin/computation.py b/eth/vm/forks/berlin/computation.py index be112fb4f6..9e65374813 100644 --- a/eth/vm/forks/berlin/computation.py +++ b/eth/vm/forks/berlin/computation.py @@ -7,10 +7,6 @@ merge, ) -from eth.precompiles.modexp import ( - extract_lengths, - modexp, -) from eth._utils.address import ( force_bytes_to_address, ) @@ -20,17 +16,21 @@ from eth._utils.padding import ( zpad_right, ) - -from eth.vm.forks.berlin import constants - -from eth.vm.forks.muir_glacier.computation import ( - MUIR_GLACIER_PRECOMPILES +from eth.precompiles.modexp import ( + extract_lengths, + modexp, +) +from eth.vm.forks.berlin import ( + constants, ) from eth.vm.forks.muir_glacier.computation import ( + MUIR_GLACIER_PRECOMPILES, MuirGlacierComputation, ) -from .opcodes import BERLIN_OPCODES +from .opcodes import ( + BERLIN_OPCODES, +) def _calculate_multiplication_complexity(base_length: int, modulus_length: int) -> int: diff --git a/eth/vm/forks/berlin/headers.py b/eth/vm/forks/berlin/headers.py index 93262f1a99..8457e9d25c 100644 --- a/eth/vm/forks/berlin/headers.py +++ b/eth/vm/forks/berlin/headers.py @@ -1,10 +1,9 @@ from eth.vm.forks.muir_glacier.headers import ( + compute_muir_glacier_difficulty, configure_header, create_header_from_parent, - compute_muir_glacier_difficulty, ) - compute_berlin_difficulty = compute_muir_glacier_difficulty create_berlin_header_from_parent = create_header_from_parent( diff --git a/eth/vm/forks/berlin/logic.py b/eth/vm/forks/berlin/logic.py index ed910357a0..3fd7e584fc 100644 --- a/eth/vm/forks/berlin/logic.py +++ b/eth/vm/forks/berlin/logic.py @@ -1,16 +1,22 @@ from eth_typing import ( Address, ) -from eth_utils.toolz import curry +from eth_utils.toolz import ( + curry, +) -from eth import constants +from eth import ( + constants, +) from eth._utils.address import ( force_bytes_to_address, ) from eth.abc import ( ComputationAPI, ) -from eth.vm import mnemonics +from eth.vm import ( + mnemonics, +) from eth.vm.forks.istanbul.storage import ( GAS_SCHEDULE_EIP2200, sstore_eip2200_generic, @@ -23,8 +29,8 @@ ) from eth.vm.logic.context import ( consume_extcodecopy_word_cost, - push_balance_of_address, extcodecopy_execute, + push_balance_of_address, ) from eth.vm.logic.storage import ( NetSStoreGasSchedule, @@ -36,7 +42,9 @@ selfdestruct_eip161_on_address, ) -from . import constants as berlin_constants +from . import ( + constants as berlin_constants, +) def _mark_address_warm(computation: ComputationAPI, address: Address) -> bool: diff --git a/eth/vm/forks/berlin/opcodes.py b/eth/vm/forks/berlin/opcodes.py index bc82b88b52..cea4c051f8 100644 --- a/eth/vm/forks/berlin/opcodes.py +++ b/eth/vm/forks/berlin/opcodes.py @@ -1,30 +1,36 @@ import copy -from typing import Dict +from typing import ( + Dict, +) -from eth_utils.toolz import merge +from eth_utils.toolz import ( + merge, +) +from eth import ( + constants, +) from eth.vm import ( mnemonics, opcode_values, ) -from eth.vm.opcode import ( - Opcode, - as_opcode, -) -from eth import constants - -from eth.vm.forks.tangerine_whistle.constants import ( - GAS_SELFDESTRUCT_EIP150, -) from eth.vm.forks.byzantium.opcodes import ( ensure_no_static, ) from eth.vm.forks.muir_glacier.opcodes import ( MUIR_GLACIER_OPCODES, ) +from eth.vm.forks.tangerine_whistle.constants import ( + GAS_SELFDESTRUCT_EIP150, +) +from eth.vm.opcode import ( + Opcode, + as_opcode, +) -from . import logic - +from . import ( + logic, +) UPDATED_OPCODES: Dict[int, Opcode] = { opcode_values.BALANCE: as_opcode( diff --git a/eth/vm/forks/berlin/receipts.py b/eth/vm/forks/berlin/receipts.py index 6c2b2b54a8..2dbb8c3e50 100644 --- a/eth/vm/forks/berlin/receipts.py +++ b/eth/vm/forks/berlin/receipts.py @@ -4,8 +4,12 @@ Type, ) -from cached_property import cached_property -from eth_bloom import BloomFilter +from cached_property import ( + cached_property, +) +from eth_bloom import ( + BloomFilter, +) from eth_utils import ( ValidationError, to_bytes, @@ -23,15 +27,18 @@ ReceiptBuilderAPI, ReceiptDecoderAPI, ) -from eth.exceptions import UnrecognizedTransactionType -from eth.rlp.receipts import Receipt +from eth.exceptions import ( + UnrecognizedTransactionType, +) +from eth.rlp.receipts import ( + Receipt, +) from .constants import ( ACCESS_LIST_TRANSACTION_TYPE, VALID_TRANSACTION_TYPES, ) - TYPED_RECEIPT_BODY_CODECS = { # Note that the body of a "type 1" receipt uses exactly the same codec as a # legacy receipt, so we can simply reuse all the logic. diff --git a/eth/vm/forks/berlin/state.py b/eth/vm/forks/berlin/state.py index b047d5f7f1..9f50216ce5 100644 --- a/eth/vm/forks/berlin/state.py +++ b/eth/vm/forks/berlin/state.py @@ -1,4 +1,6 @@ -from typing import Type +from typing import ( + Type, +) from eth.abc import ( ComputationAPI, @@ -7,13 +9,15 @@ TransactionExecutorAPI, ) from eth.vm.forks.muir_glacier.state import ( - MuirGlacierState + MuirGlacierState, ) from eth.vm.forks.spurious_dragon.state import ( SpuriousDragonTransactionExecutor, ) -from .computation import BerlinComputation +from .computation import ( + BerlinComputation, +) class BerlinTransactionExecutor(SpuriousDragonTransactionExecutor): diff --git a/eth/vm/forks/berlin/transactions.py b/eth/vm/forks/berlin/transactions.py index 83cd1e040a..b68c7fe803 100644 --- a/eth/vm/forks/berlin/transactions.py +++ b/eth/vm/forks/berlin/transactions.py @@ -4,13 +4,19 @@ Sequence, Tuple, Type, - cast, Union, + cast, ) -from cached_property import cached_property -from eth_keys.datatypes import PrivateKey -from eth_hash.auto import keccak +from cached_property import ( + cached_property, +) +from eth_hash.auto import ( + keccak, +) +from eth_keys.datatypes import ( + PrivateKey, +) from eth_typing import ( Address, Hash32, @@ -29,6 +35,12 @@ binary, ) +from eth._utils.transactions import ( + calculate_intrinsic_gas, + create_transaction_signature, + extract_transaction_sender, + validate_transaction_signature, +) from eth.abc import ( DecodedZeroOrOneLayerRLP, ReceiptAPI, @@ -37,12 +49,24 @@ TransactionDecoderAPI, UnsignedTransactionAPI, ) -from eth.constants import CREATE_CONTRACT_ADDRESS -from eth.exceptions import UnrecognizedTransactionType -from eth.rlp.logs import Log -from eth.rlp.receipts import Receipt -from eth.rlp.sedes import address -from eth.rlp.transactions import SignedTransactionMethods +from eth.constants import ( + CREATE_CONTRACT_ADDRESS, +) +from eth.exceptions import ( + UnrecognizedTransactionType, +) +from eth.rlp.logs import ( + Log, +) +from eth.rlp.receipts import ( + Receipt, +) +from eth.rlp.sedes import ( + address, +) +from eth.rlp.transactions import ( + SignedTransactionMethods, +) from eth.validation import ( validate_canonical_address, validate_is_bytes, @@ -57,13 +81,6 @@ MuirGlacierUnsignedTransaction, ) -from eth._utils.transactions import ( - calculate_intrinsic_gas, - create_transaction_signature, - extract_transaction_sender, - validate_transaction_signature, -) - from .constants import ( ACCESS_LIST_ADDRESS_COST_EIP_2930, ACCESS_LIST_STORAGE_KEY_COST_EIP_2930, diff --git a/eth/vm/forks/byzantium/blocks.py b/eth/vm/forks/byzantium/blocks.py index 3ce0d707f3..20a523e8a8 100644 --- a/eth/vm/forks/byzantium/blocks.py +++ b/eth/vm/forks/byzantium/blocks.py @@ -1,6 +1,7 @@ from rlp.sedes import ( CountableList, ) + from eth.rlp.headers import ( BlockHeader, ) diff --git a/eth/vm/forks/byzantium/computation.py b/eth/vm/forks/byzantium/computation.py index f591c3f3ca..d42fdc2751 100644 --- a/eth/vm/forks/byzantium/computation.py +++ b/eth/vm/forks/byzantium/computation.py @@ -2,14 +2,22 @@ merge, ) -from eth import precompiles +from eth import ( + precompiles, +) from eth._utils.address import ( force_bytes_to_address, ) -from eth.vm.forks.frontier.computation import FRONTIER_PRECOMPILES -from eth.vm.forks.spurious_dragon.computation import SpuriousDragonComputation +from eth.vm.forks.frontier.computation import ( + FRONTIER_PRECOMPILES, +) +from eth.vm.forks.spurious_dragon.computation import ( + SpuriousDragonComputation, +) -from .opcodes import BYZANTIUM_OPCODES +from .opcodes import ( + BYZANTIUM_OPCODES, +) BYZANTIUM_PRECOMPILES = merge( FRONTIER_PRECOMPILES, diff --git a/eth/vm/forks/byzantium/constants.py b/eth/vm/forks/byzantium/constants.py index 9c4d445d18..9bea1d0549 100644 --- a/eth/vm/forks/byzantium/constants.py +++ b/eth/vm/forks/byzantium/constants.py @@ -1,4 +1,6 @@ -from eth_utils import denoms +from eth_utils import ( + denoms, +) # # Difficulty diff --git a/eth/vm/forks/byzantium/headers.py b/eth/vm/forks/byzantium/headers.py index 6cacd0e440..a6be477229 100644 --- a/eth/vm/forks/byzantium/headers.py +++ b/eth/vm/forks/byzantium/headers.py @@ -2,26 +2,27 @@ Any, Callable, ) + from eth_utils.toolz import ( curry, ) +from eth._utils.db import ( + get_parent_header, +) +from eth._utils.headers import ( + new_timestamp_from_parent, +) from eth.abc import ( BlockHeaderAPI, VirtualMachineAPI, ) from eth.constants import ( - EMPTY_UNCLE_HASH, + BOMB_EXPONENTIAL_FREE_PERIODS, + BOMB_EXPONENTIAL_PERIOD, DIFFICULTY_ADJUSTMENT_DENOMINATOR, DIFFICULTY_MINIMUM, - BOMB_EXPONENTIAL_PERIOD, - BOMB_EXPONENTIAL_FREE_PERIODS, -) -from eth._utils.db import ( - get_parent_header, -) -from eth._utils.headers import ( - new_timestamp_from_parent, + EMPTY_UNCLE_HASH, ) from eth.validation import ( validate_gt, @@ -32,7 +33,7 @@ ) from .constants import ( - BYZANTIUM_DIFFICULTY_ADJUSTMENT_CUTOFF + BYZANTIUM_DIFFICULTY_ADJUSTMENT_CUTOFF, ) diff --git a/eth/vm/forks/byzantium/opcodes.py b/eth/vm/forks/byzantium/opcodes.py index 2760b29e9e..e9bb02f4a2 100644 --- a/eth/vm/forks/byzantium/opcodes.py +++ b/eth/vm/forks/byzantium/opcodes.py @@ -1,26 +1,37 @@ import copy import functools -from typing import Dict - -from eth_utils.toolz import merge - from typing import ( Any, Callable, + Dict, ) -from eth import constants +from eth_utils.toolz import ( + merge, +) -from eth.abc import OpcodeAPI +from eth import ( + constants, +) +from eth.abc import ( + OpcodeAPI, +) from eth.exceptions import ( WriteProtection, ) -from eth.vm import mnemonics -from eth.vm import opcode_values -from eth.vm.computation import BaseComputation +from eth.vm import ( + mnemonics, + opcode_values, +) +from eth.vm.computation import ( + BaseComputation, +) +from eth.vm.forks.spurious_dragon.opcodes import ( + SPURIOUS_DRAGON_OPCODES, +) from eth.vm.forks.tangerine_whistle.constants import ( GAS_CALL_EIP150, - GAS_SELFDESTRUCT_EIP150 + GAS_SELFDESTRUCT_EIP150, ) from eth.vm.logic import ( call, @@ -29,9 +40,9 @@ storage, system, ) -from eth.vm.opcode import as_opcode - -from eth.vm.forks.spurious_dragon.opcodes import SPURIOUS_DRAGON_OPCODES +from eth.vm.opcode import ( + as_opcode, +) def ensure_no_static(opcode_fn: Callable[..., Any]) -> Callable[..., Any]: diff --git a/eth/vm/forks/byzantium/state.py b/eth/vm/forks/byzantium/state.py index d588c62ebb..a47500e91a 100644 --- a/eth/vm/forks/byzantium/state.py +++ b/eth/vm/forks/byzantium/state.py @@ -1,6 +1,10 @@ -from eth.vm.forks.spurious_dragon.state import SpuriousDragonState +from eth.vm.forks.spurious_dragon.state import ( + SpuriousDragonState, +) -from .computation import ByzantiumComputation +from .computation import ( + ByzantiumComputation, +) class ByzantiumState(SpuriousDragonState): diff --git a/eth/vm/forks/byzantium/transactions.py b/eth/vm/forks/byzantium/transactions.py index 4f40e07ee4..91d51de838 100644 --- a/eth/vm/forks/byzantium/transactions.py +++ b/eth/vm/forks/byzantium/transactions.py @@ -1,10 +1,13 @@ -from eth_keys.datatypes import PrivateKey -from eth_typing import Address +from eth_keys.datatypes import ( + PrivateKey, +) +from eth_typing import ( + Address, +) from eth._utils.transactions import ( create_transaction_signature, ) - from eth.vm.forks.spurious_dragon.transactions import ( SpuriousDragonTransaction, SpuriousDragonUnsignedTransaction, diff --git a/eth/vm/forks/constantinople/blocks.py b/eth/vm/forks/constantinople/blocks.py index 8bd7480596..f8021ee767 100644 --- a/eth/vm/forks/constantinople/blocks.py +++ b/eth/vm/forks/constantinople/blocks.py @@ -1,6 +1,7 @@ from rlp.sedes import ( CountableList, ) + from eth.rlp.headers import ( BlockHeader, ) diff --git a/eth/vm/forks/constantinople/computation.py b/eth/vm/forks/constantinople/computation.py index 6938282470..d920a0aef8 100644 --- a/eth/vm/forks/constantinople/computation.py +++ b/eth/vm/forks/constantinople/computation.py @@ -1,15 +1,15 @@ from eth.vm.forks.byzantium.computation import ( - BYZANTIUM_PRECOMPILES -) -from eth.vm.forks.byzantium.computation import ( - ByzantiumComputation + BYZANTIUM_PRECOMPILES, + ByzantiumComputation, ) from eth.vm.gas_meter import ( - allow_negative_refund_strategy, GasMeter, + allow_negative_refund_strategy, ) -from .opcodes import CONSTANTINOPLE_OPCODES +from .opcodes import ( + CONSTANTINOPLE_OPCODES, +) CONSTANTINOPLE_PRECOMPILES = BYZANTIUM_PRECOMPILES diff --git a/eth/vm/forks/constantinople/constants.py b/eth/vm/forks/constantinople/constants.py index 3c9424f8bb..b85c0bb931 100644 --- a/eth/vm/forks/constantinople/constants.py +++ b/eth/vm/forks/constantinople/constants.py @@ -1,5 +1,6 @@ -from eth_utils import denoms - +from eth_utils import ( + denoms, +) GAS_EXTCODEHASH_EIP1052 = 400 GAS_SSTORE_EIP1283_NOOP = 200 diff --git a/eth/vm/forks/constantinople/headers.py b/eth/vm/forks/constantinople/headers.py index 4a75b016bc..d477659dce 100644 --- a/eth/vm/forks/constantinople/headers.py +++ b/eth/vm/forks/constantinople/headers.py @@ -1,10 +1,9 @@ from eth.vm.forks.byzantium.headers import ( + compute_difficulty, configure_header, create_header_from_parent, - compute_difficulty, ) - compute_constantinople_difficulty = compute_difficulty(5000000) create_constantinople_header_from_parent = create_header_from_parent( diff --git a/eth/vm/forks/constantinople/opcodes.py b/eth/vm/forks/constantinople/opcodes.py index 658b5ca4c4..9655a80e03 100644 --- a/eth/vm/forks/constantinople/opcodes.py +++ b/eth/vm/forks/constantinople/opcodes.py @@ -1,10 +1,11 @@ import copy + from eth_utils.toolz import ( - merge + merge, ) from eth import ( - constants + constants, ) from eth.vm import ( mnemonics, @@ -12,10 +13,10 @@ ) from eth.vm.forks.byzantium.opcodes import ( BYZANTIUM_OPCODES, - ensure_no_static + ensure_no_static, ) from eth.vm.forks.constantinople.constants import ( - GAS_EXTCODEHASH_EIP1052 + GAS_EXTCODEHASH_EIP1052, ) from eth.vm.forks.constantinople.storage import ( sstore_eip1283, @@ -26,10 +27,9 @@ system, ) from eth.vm.opcode import ( - as_opcode + as_opcode, ) - UPDATED_OPCODES = { opcode_values.SHL: as_opcode( logic_fn=arithmetic.shl, diff --git a/eth/vm/forks/constantinople/state.py b/eth/vm/forks/constantinople/state.py index 2ea1e877ca..e4c7956fb1 100644 --- a/eth/vm/forks/constantinople/state.py +++ b/eth/vm/forks/constantinople/state.py @@ -1,8 +1,10 @@ from eth.vm.forks.byzantium.state import ( - ByzantiumState + ByzantiumState, ) -from .computation import ConstantinopleComputation +from .computation import ( + ConstantinopleComputation, +) class ConstantinopleState(ByzantiumState): diff --git a/eth/vm/forks/constantinople/storage.py b/eth/vm/forks/constantinople/storage.py index 829444940e..ecc7ae47e7 100644 --- a/eth/vm/forks/constantinople/storage.py +++ b/eth/vm/forks/constantinople/storage.py @@ -1,8 +1,10 @@ -from functools import partial +from functools import ( + partial, +) from eth.vm.logic.storage import ( - net_sstore, NetSStoreGasSchedule, + net_sstore, ) GAS_SCHEDULE_EIP1283 = NetSStoreGasSchedule( diff --git a/eth/vm/forks/constantinople/transactions.py b/eth/vm/forks/constantinople/transactions.py index daed44e4b0..093b357b7b 100644 --- a/eth/vm/forks/constantinople/transactions.py +++ b/eth/vm/forks/constantinople/transactions.py @@ -1,14 +1,17 @@ -from eth_keys.datatypes import PrivateKey -from eth_typing import Address - -from eth.vm.forks.byzantium.transactions import ( - ByzantiumTransaction, - ByzantiumUnsignedTransaction, +from eth_keys.datatypes import ( + PrivateKey, +) +from eth_typing import ( + Address, ) from eth._utils.transactions import ( create_transaction_signature, ) +from eth.vm.forks.byzantium.transactions import ( + ByzantiumTransaction, + ByzantiumUnsignedTransaction, +) class ConstantinopleTransaction(ByzantiumTransaction): diff --git a/eth/vm/forks/frontier/blocks.py b/eth/vm/forks/frontier/blocks.py index 75ce44bc40..7145771f03 100644 --- a/eth/vm/forks/frontier/blocks.py +++ b/eth/vm/forks/frontier/blocks.py @@ -4,19 +4,16 @@ Type, ) -from rlp.sedes import ( - CountableList, -) - from eth_bloom import ( BloomFilter, ) - from eth_typing import ( BlockNumber, Hash32, ) - +from rlp.sedes import ( + CountableList, +) from trie.exceptions import ( MissingTrieNode, ) diff --git a/eth/vm/forks/frontier/computation.py b/eth/vm/forks/frontier/computation.py index cf0b6ae537..eba5776cb7 100644 --- a/eth/vm/forks/frontier/computation.py +++ b/eth/vm/forks/frontier/computation.py @@ -1,15 +1,13 @@ -from eth import precompiles - -from eth_hash.auto import keccak +from eth_hash.auto import ( + keccak, +) from eth_utils import ( encode_hex, ) -from eth.constants import ( - GAS_CODEDEPOSIT, - STACK_DEPTH_LIMIT, +from eth import ( + precompiles, ) - from eth._utils.address import ( force_bytes_to_address, ) @@ -19,17 +17,22 @@ StateAPI, TransactionContextAPI, ) +from eth.constants import ( + GAS_CODEDEPOSIT, + STACK_DEPTH_LIMIT, +) from eth.exceptions import ( - OutOfGas, InsufficientFunds, + OutOfGas, StackDepthLimit, ) from eth.vm.computation import ( BaseComputation, ) -from .opcodes import FRONTIER_OPCODES - +from .opcodes import ( + FRONTIER_OPCODES, +) FRONTIER_PRECOMPILES = { force_bytes_to_address(b'\x01'): precompiles.ecrecover, diff --git a/eth/vm/forks/frontier/headers.py b/eth/vm/forks/frontier/headers.py index f7fce87301..d71bd60d87 100644 --- a/eth/vm/forks/frontier/headers.py +++ b/eth/vm/forks/frontier/headers.py @@ -1,21 +1,8 @@ from typing import ( - Any, TYPE_CHECKING, + Any, ) -from eth.abc import BlockHeaderAPI -from eth.validation import ( - validate_gt, - validate_header_params_for_configuration, -) - -from eth.constants import ( - GENESIS_GAS_LIMIT, - DIFFICULTY_ADJUSTMENT_DENOMINATOR, - DIFFICULTY_MINIMUM, - BOMB_EXPONENTIAL_PERIOD, - BOMB_EXPONENTIAL_FREE_PERIODS, -) from eth._utils.db import ( get_parent_header, ) @@ -24,14 +11,30 @@ fill_header_params_from_parent, new_timestamp_from_parent, ) -from eth.rlp.headers import BlockHeader +from eth.abc import ( + BlockHeaderAPI, +) +from eth.constants import ( + BOMB_EXPONENTIAL_FREE_PERIODS, + BOMB_EXPONENTIAL_PERIOD, + DIFFICULTY_ADJUSTMENT_DENOMINATOR, + DIFFICULTY_MINIMUM, + GENESIS_GAS_LIMIT, +) +from eth.rlp.headers import ( + BlockHeader, +) +from eth.validation import ( + validate_gt, + validate_header_params_for_configuration, +) from .constants import ( - FRONTIER_DIFFICULTY_ADJUSTMENT_CUTOFF + FRONTIER_DIFFICULTY_ADJUSTMENT_CUTOFF, ) if TYPE_CHECKING: - from eth.vm.forks.frontier import FrontierVM # noqa: F401 + from eth.vm.forks.frontier import FrontierVM # noqa: F401 def compute_frontier_difficulty(parent_header: BlockHeaderAPI, timestamp: int) -> int: diff --git a/eth/vm/forks/frontier/opcodes.py b/eth/vm/forks/frontier/opcodes.py index c265338250..1b5f2158d9 100644 --- a/eth/vm/forks/frontier/opcodes.py +++ b/eth/vm/forks/frontier/opcodes.py @@ -1,10 +1,17 @@ -from typing import Dict - -from eth import constants +from typing import ( + Dict, +) -from eth.abc import OpcodeAPI -from eth.vm import mnemonics -from eth.vm import opcode_values +from eth import ( + constants, +) +from eth.abc import ( + OpcodeAPI, +) +from eth.vm import ( + mnemonics, + opcode_values, +) from eth.vm.logic import ( arithmetic, block, @@ -25,7 +32,6 @@ as_opcode, ) - FRONTIER_OPCODES: Dict[int, OpcodeAPI] = { # # Arithmetic diff --git a/eth/vm/forks/frontier/state.py b/eth/vm/forks/frontier/state.py index d5ae8878d1..3567a549ac 100644 --- a/eth/vm/forks/frontier/state.py +++ b/eth/vm/forks/frontier/state.py @@ -1,30 +1,34 @@ -from typing import Type +from typing import ( + Type, +) -from eth_hash.auto import keccak +from eth_hash.auto import ( + keccak, +) from eth_utils import ( encode_hex, ) +from eth._utils.address import ( + generate_contract_address, +) from eth.abc import ( AccountDatabaseAPI, ComputationAPI, - SignedTransactionAPI, MessageAPI, + SignedTransactionAPI, TransactionContextAPI, TransactionExecutorAPI, ) -from eth.constants import CREATE_CONTRACT_ADDRESS +from eth.constants import ( + CREATE_CONTRACT_ADDRESS, +) from eth.db.account import ( AccountDB, ) from eth.exceptions import ( ContractCreationCollision, ) - -from eth._utils.address import ( - generate_contract_address, -) - from eth.vm.message import ( Message, ) @@ -33,16 +37,19 @@ BaseTransactionExecutor, ) - -from .computation import FrontierComputation +from .computation import ( + FrontierComputation, +) from .constants import ( - REFUND_SELFDESTRUCT, MAX_REFUND_QUOTIENT, + REFUND_SELFDESTRUCT, ) from .transaction_context import ( - FrontierTransactionContext + FrontierTransactionContext, +) +from .validation import ( + validate_frontier_transaction, ) -from .validation import validate_frontier_transaction class FrontierTransactionExecutor(BaseTransactionExecutor): diff --git a/eth/vm/forks/frontier/transaction_context.py b/eth/vm/forks/frontier/transaction_context.py index 4f63c6fc9a..fc5520a59d 100644 --- a/eth/vm/forks/frontier/transaction_context.py +++ b/eth/vm/forks/frontier/transaction_context.py @@ -1,4 +1,6 @@ -from eth.vm.transaction_context import BaseTransactionContext +from eth.vm.transaction_context import ( + BaseTransactionContext, +) class FrontierTransactionContext(BaseTransactionContext): diff --git a/eth/vm/forks/frontier/transactions.py b/eth/vm/forks/frontier/transactions.py index d6e0d4bf34..49557aeb3a 100644 --- a/eth/vm/forks/frontier/transactions.py +++ b/eth/vm/forks/frontier/transactions.py @@ -1,14 +1,26 @@ -from functools import partial +from functools import ( + partial, +) from typing import ( Tuple, ) -from eth_keys.datatypes import PrivateKey +from eth_keys.datatypes import ( + PrivateKey, +) from eth_typing import ( Address, ) import rlp +from eth._utils.transactions import ( + V_OFFSET, + IntrinsicGasSchedule, + calculate_intrinsic_gas, + create_transaction_signature, + extract_transaction_sender, + validate_transaction_signature, +) from eth.abc import ( ReceiptAPI, SignedTransactionAPI, @@ -16,36 +28,29 @@ from eth.constants import ( CREATE_CONTRACT_ADDRESS, GAS_TX, - GAS_TXDATAZERO, GAS_TXDATANONZERO, + GAS_TXDATAZERO, ) -from eth.validation import ( - validate_uint256, - validate_is_integer, - validate_is_bytes, - validate_lt_secpk1n, - validate_lte, - validate_gte, - validate_canonical_address, +from eth.rlp.logs import ( + Log, +) +from eth.rlp.receipts import ( + Receipt, ) - -from eth.rlp.logs import Log -from eth.rlp.receipts import Receipt from eth.rlp.transactions import ( BaseTransaction, BaseUnsignedTransaction, ) - -from eth._utils.transactions import ( - V_OFFSET, - create_transaction_signature, - extract_transaction_sender, - validate_transaction_signature, - IntrinsicGasSchedule, - calculate_intrinsic_gas, +from eth.validation import ( + validate_canonical_address, + validate_gte, + validate_is_bytes, + validate_is_integer, + validate_lt_secpk1n, + validate_lte, + validate_uint256, ) - FRONTIER_TX_GAS_SCHEDULE = IntrinsicGasSchedule( gas_tx=GAS_TX, gas_txcreate=0, diff --git a/eth/vm/forks/gray_glacier/blocks.py b/eth/vm/forks/gray_glacier/blocks.py index 58f0a43273..be1609648d 100644 --- a/eth/vm/forks/gray_glacier/blocks.py +++ b/eth/vm/forks/gray_glacier/blocks.py @@ -1,18 +1,21 @@ -from abc import ABC -from typing import Type +from abc import ( + ABC, +) +from typing import ( + Type, +) -from eth.abc import TransactionBuilderAPI from eth_utils import ( encode_hex, ) - from rlp.sedes import ( CountableList, ) -from .transactions import ( - GrayGlacierTransactionBuilder, +from eth.abc import ( + TransactionBuilderAPI, ) + from ..arrow_glacier import ( ArrowGlacierBlock, ) @@ -20,7 +23,12 @@ ArrowGlacierBlockHeader, ArrowGlacierMiningHeader, ) -from ..london.blocks import LondonBackwardsHeader +from ..london.blocks import ( + LondonBackwardsHeader, +) +from .transactions import ( + GrayGlacierTransactionBuilder, +) class GrayGlacierMiningHeader(ArrowGlacierMiningHeader, ABC): diff --git a/eth/vm/forks/gray_glacier/computation.py b/eth/vm/forks/gray_glacier/computation.py index 00428e6857..6aeb6a261f 100644 --- a/eth/vm/forks/gray_glacier/computation.py +++ b/eth/vm/forks/gray_glacier/computation.py @@ -1,4 +1,6 @@ -from ..arrow_glacier.computation import ArrowGlacierComputation +from ..arrow_glacier.computation import ( + ArrowGlacierComputation, +) class GrayGlacierComputation(ArrowGlacierComputation): diff --git a/eth/vm/forks/gray_glacier/headers.py b/eth/vm/forks/gray_glacier/headers.py index 2896f0c75e..b24fa412eb 100644 --- a/eth/vm/forks/gray_glacier/headers.py +++ b/eth/vm/forks/gray_glacier/headers.py @@ -1,10 +1,13 @@ -from typing import Any, Callable, Optional - -from toolz import curry +from typing import ( + Any, + Callable, + Optional, +) -from .blocks import ( - GrayGlacierBlockHeader, +from toolz import ( + curry, ) + from eth.abc import ( BlockHeaderAPI, ) @@ -13,11 +16,13 @@ ) from eth.vm.forks.byzantium.headers import ( compute_difficulty, -) -from eth.vm.forks.byzantium.headers import ( configure_header, ) +from .blocks import ( + GrayGlacierBlockHeader, +) + compute_gray_glacier_difficulty = compute_difficulty(11_400_000) configure_gray_glacier_header = configure_header(difficulty_fn=compute_gray_glacier_difficulty) diff --git a/eth/vm/forks/gray_glacier/state.py b/eth/vm/forks/gray_glacier/state.py index 68e7a99385..0e9e3ea627 100644 --- a/eth/vm/forks/gray_glacier/state.py +++ b/eth/vm/forks/gray_glacier/state.py @@ -1,9 +1,20 @@ -from typing import Type +from typing import ( + Type, +) -from eth.abc import TransactionExecutorAPI -from .computation import GrayGlacierComputation -from ..arrow_glacier import ArrowGlacierState -from ..arrow_glacier.state import ArrowGlacierTransactionExecutor +from eth.abc import ( + TransactionExecutorAPI, +) + +from ..arrow_glacier import ( + ArrowGlacierState, +) +from ..arrow_glacier.state import ( + ArrowGlacierTransactionExecutor, +) +from .computation import ( + GrayGlacierComputation, +) class GrayGlacierTransactionExecutor(ArrowGlacierTransactionExecutor): diff --git a/eth/vm/forks/gray_glacier/transactions.py b/eth/vm/forks/gray_glacier/transactions.py index 008be551f6..ab4d758695 100644 --- a/eth/vm/forks/gray_glacier/transactions.py +++ b/eth/vm/forks/gray_glacier/transactions.py @@ -1,6 +1,10 @@ -from abc import ABC +from abc import ( + ABC, +) -from eth_keys.datatypes import PrivateKey +from eth_keys.datatypes import ( + PrivateKey, +) from eth._utils.transactions import ( create_transaction_signature, diff --git a/eth/vm/forks/homestead/blocks.py b/eth/vm/forks/homestead/blocks.py index 5555f26e3f..53aa27b706 100644 --- a/eth/vm/forks/homestead/blocks.py +++ b/eth/vm/forks/homestead/blocks.py @@ -1,12 +1,14 @@ from rlp.sedes import ( CountableList, ) + from eth.rlp.headers import ( BlockHeader, ) from eth.vm.forks.frontier.blocks import ( FrontierBlock, ) + from .transactions import ( HomesteadTransaction, ) diff --git a/eth/vm/forks/homestead/computation.py b/eth/vm/forks/homestead/computation.py index bafa9d9d27..e74e97f884 100644 --- a/eth/vm/forks/homestead/computation.py +++ b/eth/vm/forks/homestead/computation.py @@ -1,24 +1,29 @@ -from eth_hash.auto import keccak - -from eth import constants -from eth.exceptions import ( - OutOfGas, +from eth_hash.auto import ( + keccak, ) from eth_utils import ( encode_hex, ) +from eth import ( + constants, +) from eth.abc import ( ComputationAPI, MessageAPI, StateAPI, TransactionContextAPI, ) +from eth.exceptions import ( + OutOfGas, +) from eth.vm.forks.frontier.computation import ( FrontierComputation, ) -from .opcodes import HOMESTEAD_OPCODES +from .opcodes import ( + HOMESTEAD_OPCODES, +) class HomesteadComputation(FrontierComputation): diff --git a/eth/vm/forks/homestead/headers.py b/eth/vm/forks/homestead/headers.py index 2008b68d2d..9868e41217 100644 --- a/eth/vm/forks/homestead/headers.py +++ b/eth/vm/forks/homestead/headers.py @@ -1,6 +1,6 @@ from typing import ( - Any, TYPE_CHECKING, + Any, ) from eth_typing import ( @@ -10,16 +10,20 @@ decode_hex, ) -from eth.abc import BlockHeaderAPI +from eth._utils.db import ( + get_parent_header, +) +from eth.abc import ( + BlockHeaderAPI, +) from eth.constants import ( + BOMB_EXPONENTIAL_FREE_PERIODS, + BOMB_EXPONENTIAL_PERIOD, DIFFICULTY_ADJUSTMENT_DENOMINATOR, DIFFICULTY_MINIMUM, - BOMB_EXPONENTIAL_PERIOD, - BOMB_EXPONENTIAL_FREE_PERIODS, ) -from eth.rlp.headers import BlockHeader -from eth._utils.db import ( - get_parent_header, +from eth.rlp.headers import ( + BlockHeader, ) from eth.validation import ( validate_gt, @@ -30,11 +34,11 @@ ) from .constants import ( - HOMESTEAD_DIFFICULTY_ADJUSTMENT_CUTOFF + HOMESTEAD_DIFFICULTY_ADJUSTMENT_CUTOFF, ) if TYPE_CHECKING: - from eth.vm.forks.homestead import HomesteadVM # noqa: F401 + from eth.vm.forks.homestead import HomesteadVM # noqa: F401 def compute_homestead_difficulty(parent_header: BlockHeaderAPI, timestamp: int) -> int: diff --git a/eth/vm/forks/homestead/opcodes.py b/eth/vm/forks/homestead/opcodes.py index a3104dcf25..9e3a58ad81 100644 --- a/eth/vm/forks/homestead/opcodes.py +++ b/eth/vm/forks/homestead/opcodes.py @@ -1,19 +1,29 @@ import copy -from typing import Dict +from typing import ( + Dict, +) -from eth_utils.toolz import merge +from eth_utils.toolz import ( + merge, +) -from eth import constants -from eth.abc import OpcodeAPI -from eth.vm import mnemonics -from eth.vm import opcode_values +from eth import ( + constants, +) +from eth.abc import ( + OpcodeAPI, +) +from eth.vm import ( + mnemonics, + opcode_values, +) +from eth.vm.forks.frontier.opcodes import ( + FRONTIER_OPCODES, +) from eth.vm.logic import ( call, ) -from eth.vm.forks.frontier.opcodes import FRONTIER_OPCODES - - NEW_OPCODES = { opcode_values.DELEGATECALL: call.DelegateCall.configure( __name__='opcode:DELEGATECALL', diff --git a/eth/vm/forks/homestead/state.py b/eth/vm/forks/homestead/state.py index e828bf1b55..4284496c66 100644 --- a/eth/vm/forks/homestead/state.py +++ b/eth/vm/forks/homestead/state.py @@ -1,4 +1,6 @@ -from typing import Type +from typing import ( + Type, +) from eth.abc import ( ComputationAPI, @@ -9,8 +11,12 @@ FrontierTransactionExecutor, ) -from .computation import HomesteadComputation -from .validation import validate_homestead_transaction +from .computation import ( + HomesteadComputation, +) +from .validation import ( + validate_homestead_transaction, +) class HomesteadState(FrontierState): diff --git a/eth/vm/forks/homestead/transactions.py b/eth/vm/forks/homestead/transactions.py index f9ba670d17..0cdc3eb6be 100644 --- a/eth/vm/forks/homestead/transactions.py +++ b/eth/vm/forks/homestead/transactions.py @@ -1,26 +1,29 @@ -from functools import partial +from functools import ( + partial, +) +from eth_keys.datatypes import ( + PrivateKey, +) +from eth_typing import ( + Address, +) import rlp -from eth_keys.datatypes import PrivateKey - -from eth_typing import Address - -from eth.constants import GAS_TXCREATE - +from eth._utils.transactions import ( + calculate_intrinsic_gas, + create_transaction_signature, +) +from eth.constants import ( + GAS_TXCREATE, +) from eth.validation import ( validate_lt_secpk1n2, ) - from eth.vm.forks.frontier.transactions import ( + FRONTIER_TX_GAS_SCHEDULE, FrontierTransaction, FrontierUnsignedTransaction, - FRONTIER_TX_GAS_SCHEDULE, -) - -from eth._utils.transactions import ( - create_transaction_signature, - calculate_intrinsic_gas, ) HOMESTEAD_TX_GAS_SCHEDULE = FRONTIER_TX_GAS_SCHEDULE._replace( diff --git a/eth/vm/forks/homestead/validation.py b/eth/vm/forks/homestead/validation.py index b02ecf5031..dca1158893 100644 --- a/eth/vm/forks/homestead/validation.py +++ b/eth/vm/forks/homestead/validation.py @@ -2,14 +2,13 @@ ValidationError, ) -from eth.constants import ( - SECPK1_N, -) - from eth.abc import ( SignedTransactionAPI, StateAPI, ) +from eth.constants import ( + SECPK1_N, +) from eth.vm.forks.frontier.validation import ( validate_frontier_transaction, ) diff --git a/eth/vm/forks/istanbul/blocks.py b/eth/vm/forks/istanbul/blocks.py index 414ee1ac1d..9a6e89b64a 100644 --- a/eth/vm/forks/istanbul/blocks.py +++ b/eth/vm/forks/istanbul/blocks.py @@ -1,6 +1,7 @@ from rlp.sedes import ( CountableList, ) + from eth.rlp.headers import ( BlockHeader, ) diff --git a/eth/vm/forks/istanbul/computation.py b/eth/vm/forks/istanbul/computation.py index 564064c25d..0299bb2c69 100644 --- a/eth/vm/forks/istanbul/computation.py +++ b/eth/vm/forks/istanbul/computation.py @@ -2,19 +2,19 @@ merge, ) -from eth import precompiles +from eth import ( + precompiles, +) from eth._utils.address import ( force_bytes_to_address, ) from eth.vm.forks.petersburg.computation import ( - PETERSBURG_PRECOMPILES -) -from eth.vm.forks.petersburg.computation import ( + PETERSBURG_PRECOMPILES, PetersburgComputation, ) from eth.vm.gas_meter import ( - allow_negative_refund_strategy, GasMeter, + allow_negative_refund_strategy, ) from .constants import ( @@ -23,7 +23,9 @@ GAS_ECPAIRING_BASE, GAS_ECPAIRING_PER_POINT, ) -from .opcodes import ISTANBUL_OPCODES +from .opcodes import ( + ISTANBUL_OPCODES, +) ISTANBUL_PRECOMPILES = merge( PETERSBURG_PRECOMPILES, diff --git a/eth/vm/forks/istanbul/headers.py b/eth/vm/forks/istanbul/headers.py index 78d206ad8d..ba3066a583 100644 --- a/eth/vm/forks/istanbul/headers.py +++ b/eth/vm/forks/istanbul/headers.py @@ -1,10 +1,9 @@ from eth.vm.forks.petersburg.headers import ( + compute_petersburg_difficulty, configure_header, create_header_from_parent, - compute_petersburg_difficulty, ) - compute_istanbul_difficulty = compute_petersburg_difficulty create_istanbul_header_from_parent = create_header_from_parent( diff --git a/eth/vm/forks/istanbul/opcodes.py b/eth/vm/forks/istanbul/opcodes.py index b0f7e9d754..2a0a11eb6b 100644 --- a/eth/vm/forks/istanbul/opcodes.py +++ b/eth/vm/forks/istanbul/opcodes.py @@ -1,33 +1,39 @@ import copy -from eth_utils.toolz import merge +from eth_utils.toolz import ( + merge, +) -from eth import constants +from eth import ( + constants, +) from eth.vm import ( mnemonics, opcode_values, ) from eth.vm.forks.byzantium.opcodes import ( - ensure_no_static -) -from eth.vm.forks.petersburg.opcodes import ( - PETERSBURG_OPCODES, + ensure_no_static, ) from eth.vm.forks.istanbul.constants import ( GAS_BALANCE_EIP1884, - GAS_SLOAD_EIP1884, GAS_EXTCODEHASH_EIP1884, + GAS_SLOAD_EIP1884, +) +from eth.vm.forks.petersburg.opcodes import ( + PETERSBURG_OPCODES, ) from eth.vm.logic import ( context, storage, ) -from eth.vm.opcode import as_opcode +from eth.vm.opcode import ( + as_opcode, +) + from .storage import ( sstore_eip2200, ) - UPDATED_OPCODES = { # New opcodes opcode_values.CHAINID: as_opcode( diff --git a/eth/vm/forks/istanbul/state.py b/eth/vm/forks/istanbul/state.py index a2f2f10c5d..448a7834d5 100644 --- a/eth/vm/forks/istanbul/state.py +++ b/eth/vm/forks/istanbul/state.py @@ -1,8 +1,10 @@ from eth.vm.forks.petersburg.state import ( - PetersburgState + PetersburgState, ) -from .computation import IstanbulComputation +from .computation import ( + IstanbulComputation, +) class IstanbulState(PetersburgState): diff --git a/eth/vm/forks/istanbul/storage.py b/eth/vm/forks/istanbul/storage.py index e0fab3a250..a1201367a7 100644 --- a/eth/vm/forks/istanbul/storage.py +++ b/eth/vm/forks/istanbul/storage.py @@ -1,12 +1,18 @@ -from eth_utils.toolz import curry +from eth_utils.toolz import ( + curry, +) -from eth.exceptions import OutOfGas -from eth.vm.computation import BaseComputation +from eth.exceptions import ( + OutOfGas, +) +from eth.vm.computation import ( + BaseComputation, +) from eth.vm.forks.constantinople.storage import ( GAS_SCHEDULE_EIP1283, ) from eth.vm.forks.istanbul import ( - constants + constants, ) from eth.vm.logic.storage import ( NetSStoreGasSchedule, diff --git a/eth/vm/forks/istanbul/transactions.py b/eth/vm/forks/istanbul/transactions.py index 2e0e6b7041..76da9a04b1 100644 --- a/eth/vm/forks/istanbul/transactions.py +++ b/eth/vm/forks/istanbul/transactions.py @@ -1,20 +1,25 @@ -from functools import partial - -from eth_keys.datatypes import PrivateKey -from eth_typing import Address +from functools import ( + partial, +) -from eth.vm.forks.petersburg.transactions import ( - PetersburgTransaction, - PetersburgUnsignedTransaction, +from eth_keys.datatypes import ( + PrivateKey, +) +from eth_typing import ( + Address, ) from eth._utils.transactions import ( - create_transaction_signature, calculate_intrinsic_gas, + create_transaction_signature, ) from eth.vm.forks.homestead.transactions import ( HOMESTEAD_TX_GAS_SCHEDULE, ) +from eth.vm.forks.petersburg.transactions import ( + PetersburgTransaction, + PetersburgUnsignedTransaction, +) from .constants import ( GAS_TXDATANONZERO_EIP2028, diff --git a/eth/vm/forks/london/blocks.py b/eth/vm/forks/london/blocks.py index 9526887fd0..a4926df6c4 100644 --- a/eth/vm/forks/london/blocks.py +++ b/eth/vm/forks/london/blocks.py @@ -5,13 +5,15 @@ cast, ) -from eth_hash.auto import keccak +from eth_hash.auto import ( + keccak, +) from eth_typing import ( BlockNumber, ) from eth_typing.evm import ( Address, - Hash32 + Hash32, ) from eth_utils import ( encode_hex, @@ -21,7 +23,7 @@ Binary, CountableList, big_endian_int, - binary + binary, ) from eth._utils.headers import ( @@ -35,12 +37,12 @@ TransactionBuilderAPI, ) from eth.constants import ( - ZERO_ADDRESS, - ZERO_HASH32, + BLANK_ROOT_HASH, EMPTY_UNCLE_HASH, GENESIS_NONCE, GENESIS_PARENT_HASH, - BLANK_ROOT_HASH, + ZERO_ADDRESS, + ZERO_HASH32, ) from eth.rlp.headers import ( BlockHeader, diff --git a/eth/vm/forks/london/computation.py b/eth/vm/forks/london/computation.py index ae72e8d627..258f99d050 100644 --- a/eth/vm/forks/london/computation.py +++ b/eth/vm/forks/london/computation.py @@ -1,10 +1,16 @@ -from eth.exceptions import ReservedBytesInCode +from eth.exceptions import ( + ReservedBytesInCode, +) from eth.vm.forks.berlin.computation import ( BerlinComputation, ) -from .opcodes import LONDON_OPCODES -from ..london.constants import EIP3541_RESERVED_STARTING_BYTE +from ..london.constants import ( + EIP3541_RESERVED_STARTING_BYTE, +) +from .opcodes import ( + LONDON_OPCODES, +) class LondonComputation(BerlinComputation): diff --git a/eth/vm/forks/london/headers.py b/eth/vm/forks/london/headers.py index 06c5352868..afe2eb683c 100644 --- a/eth/vm/forks/london/headers.py +++ b/eth/vm/forks/london/headers.py @@ -8,7 +8,9 @@ from eth_utils import ( ValidationError, ) -from toolz.functoolz import curry +from toolz.functoolz import ( + curry, +) from eth._utils.headers import ( compute_gas_limit, @@ -19,8 +21,12 @@ BlockHeaderAPI, BlockHeaderSedesAPI, ) -from eth.constants import GENESIS_GAS_LIMIT -from eth.rlp.headers import BlockHeader +from eth.constants import ( + GENESIS_GAS_LIMIT, +) +from eth.rlp.headers import ( + BlockHeader, +) from eth.vm.forks.berlin.headers import ( configure_header, ) @@ -28,8 +34,9 @@ compute_difficulty, ) - -from .blocks import LondonBlockHeader +from .blocks import ( + LondonBlockHeader, +) from .constants import ( BASE_FEE_MAX_CHANGE_DENOMINATOR, ELASTICITY_MULTIPLIER, diff --git a/eth/vm/forks/london/opcodes.py b/eth/vm/forks/london/opcodes.py index 2b1d738044..a3b25f2952 100644 --- a/eth/vm/forks/london/opcodes.py +++ b/eth/vm/forks/london/opcodes.py @@ -1,29 +1,36 @@ import copy -from typing import Dict +from typing import ( + Dict, +) -from eth_utils.toolz import merge +from eth_utils.toolz import ( + merge, +) -from eth.vm.logic import ( - block, +from eth import ( + constants, ) from eth.vm import ( mnemonics, opcode_values, ) -from eth.vm.opcode import ( - Opcode, - as_opcode, -) -from eth import constants - from eth.vm.forks.berlin.opcodes import ( BERLIN_OPCODES, ) from eth.vm.forks.byzantium.opcodes import ( ensure_no_static, ) +from eth.vm.logic import ( + block, +) +from eth.vm.opcode import ( + Opcode, + as_opcode, +) -from . import storage +from . import ( + storage, +) UPDATED_OPCODES: Dict[int, Opcode] = { opcode_values.BASEFEE: as_opcode( diff --git a/eth/vm/forks/london/receipts.py b/eth/vm/forks/london/receipts.py index 105ec9489a..2a7d8ab7b1 100644 --- a/eth/vm/forks/london/receipts.py +++ b/eth/vm/forks/london/receipts.py @@ -6,15 +6,17 @@ from eth.rlp.receipts import ( Receipt, ) +from eth.vm.forks.berlin.constants import ( + ACCESS_LIST_TRANSACTION_TYPE, +) from eth.vm.forks.berlin.receipts import ( BerlinReceiptBuilder, TypedReceipt as BerlinTypedReceipt, ) -from eth.vm.forks.berlin.constants import ( - ACCESS_LIST_TRANSACTION_TYPE, -) -from .constants import DYNAMIC_FEE_TRANSACTION_TYPE +from .constants import ( + DYNAMIC_FEE_TRANSACTION_TYPE, +) class LondonTypedReceipt(BerlinTypedReceipt): diff --git a/eth/vm/forks/london/state.py b/eth/vm/forks/london/state.py index 51c58be21f..91e833169e 100644 --- a/eth/vm/forks/london/state.py +++ b/eth/vm/forks/london/state.py @@ -1,10 +1,17 @@ -from typing import Type +from typing import ( + Type, +) -from eth_hash.auto import keccak +from eth_hash.auto import ( + keccak, +) from eth_utils import ( encode_hex, ) +from eth._utils.address import ( + generate_contract_address, +) from eth.abc import ( ComputationAPI, MessageAPI, @@ -16,20 +23,23 @@ from eth.constants import ( CREATE_CONTRACT_ADDRESS, ) -from eth.vm.message import ( - Message, -) from eth.vm.forks.berlin.state import ( BerlinState, BerlinTransactionExecutor, ) -from eth._utils.address import ( - generate_contract_address, +from eth.vm.message import ( + Message, ) -from .computation import LondonComputation -from .validation import validate_london_normalized_transaction -from .constants import EIP3529_MAX_REFUND_QUOTIENT +from .computation import ( + LondonComputation, +) +from .constants import ( + EIP3529_MAX_REFUND_QUOTIENT, +) +from .validation import ( + validate_london_normalized_transaction, +) class LondonTransactionExecutor(BerlinTransactionExecutor): diff --git a/eth/vm/forks/london/storage.py b/eth/vm/forks/london/storage.py index a72f663a0c..96e84732b1 100644 --- a/eth/vm/forks/london/storage.py +++ b/eth/vm/forks/london/storage.py @@ -1,12 +1,15 @@ -from eth_utils.toolz import partial +from eth_utils.toolz import ( + partial, +) -from eth.vm.forks.berlin import constants as berlin_constants +from eth.vm.forks.berlin import ( + constants as berlin_constants, +) from eth.vm.forks.berlin.logic import ( GAS_SCHEDULE_EIP2929, sstore_eip2929_generic, ) - SSTORE_CLEARS_SCHEDULE_EIP_3529 = ( GAS_SCHEDULE_EIP2929.sstore_reset_gas + berlin_constants.ACCESS_LIST_STORAGE_KEY_COST_EIP_2930 diff --git a/eth/vm/forks/london/transactions.py b/eth/vm/forks/london/transactions.py index 74cf58d50b..8550748623 100644 --- a/eth/vm/forks/london/transactions.py +++ b/eth/vm/forks/london/transactions.py @@ -1,4 +1,3 @@ -from cached_property import cached_property from typing import ( Dict, Sequence, @@ -7,7 +6,12 @@ Union, ) -from eth_keys.datatypes import PrivateKey +from cached_property import ( + cached_property, +) +from eth_keys.datatypes import ( + PrivateKey, +) from eth_typing import ( Address, Hash32, @@ -33,11 +37,21 @@ SignedTransactionAPI, TransactionDecoderAPI, ) -from eth.constants import CREATE_CONTRACT_ADDRESS -from eth.rlp.logs import Log -from eth.rlp.receipts import Receipt -from eth.rlp.transactions import SignedTransactionMethods -from eth.rlp.sedes import address +from eth.constants import ( + CREATE_CONTRACT_ADDRESS, +) +from eth.rlp.logs import ( + Log, +) +from eth.rlp.receipts import ( + Receipt, +) +from eth.rlp.sedes import ( + address, +) +from eth.rlp.transactions import ( + SignedTransactionMethods, +) from eth.validation import ( validate_canonical_address, validate_is_bytes, @@ -61,8 +75,12 @@ ISTANBUL_TX_GAS_SCHEDULE, ) -from .constants import DYNAMIC_FEE_TRANSACTION_TYPE -from .receipts import LondonReceiptBuilder +from .constants import ( + DYNAMIC_FEE_TRANSACTION_TYPE, +) +from .receipts import ( + LondonReceiptBuilder, +) class LondonLegacyTransaction(BerlinLegacyTransaction): diff --git a/eth/vm/forks/london/validation.py b/eth/vm/forks/london/validation.py index 4b4c0e09d2..c41c45159d 100644 --- a/eth/vm/forks/london/validation.py +++ b/eth/vm/forks/london/validation.py @@ -1,8 +1,10 @@ -from eth_utils.exceptions import ValidationError +from eth_utils.exceptions import ( + ValidationError, +) from eth.abc import ( SignedTransactionAPI, - StateAPI + StateAPI, ) from eth.vm.forks.homestead.validation import ( validate_homestead_transaction, diff --git a/eth/vm/forks/muir_glacier/blocks.py b/eth/vm/forks/muir_glacier/blocks.py index c53915065a..4591c444c9 100644 --- a/eth/vm/forks/muir_glacier/blocks.py +++ b/eth/vm/forks/muir_glacier/blocks.py @@ -1,6 +1,7 @@ from rlp.sedes import ( CountableList, ) + from eth.rlp.headers import ( BlockHeader, ) diff --git a/eth/vm/forks/muir_glacier/computation.py b/eth/vm/forks/muir_glacier/computation.py index 722273f5c8..f4942ab798 100644 --- a/eth/vm/forks/muir_glacier/computation.py +++ b/eth/vm/forks/muir_glacier/computation.py @@ -1,11 +1,11 @@ from eth.vm.forks.istanbul.computation import ( - ISTANBUL_PRECOMPILES -) -from eth.vm.forks.istanbul.computation import ( + ISTANBUL_PRECOMPILES, IstanbulComputation, ) -from .opcodes import MUIR_GLACIER_OPCODES +from .opcodes import ( + MUIR_GLACIER_OPCODES, +) MUIR_GLACIER_PRECOMPILES = ISTANBUL_PRECOMPILES diff --git a/eth/vm/forks/muir_glacier/headers.py b/eth/vm/forks/muir_glacier/headers.py index 906342ea41..9eaf43a4df 100644 --- a/eth/vm/forks/muir_glacier/headers.py +++ b/eth/vm/forks/muir_glacier/headers.py @@ -1,11 +1,10 @@ -from eth.vm.forks.petersburg.headers import ( - compute_difficulty, -) from eth.vm.forks.istanbul.headers import ( configure_header, create_header_from_parent, ) - +from eth.vm.forks.petersburg.headers import ( + compute_difficulty, +) compute_muir_glacier_difficulty = compute_difficulty(9000000) diff --git a/eth/vm/forks/muir_glacier/opcodes.py b/eth/vm/forks/muir_glacier/opcodes.py index b0c1df773b..e1bcbec419 100644 --- a/eth/vm/forks/muir_glacier/opcodes.py +++ b/eth/vm/forks/muir_glacier/opcodes.py @@ -1,7 +1,7 @@ import copy + from eth.vm.forks.istanbul.opcodes import ( ISTANBUL_OPCODES, ) - MUIR_GLACIER_OPCODES = copy.deepcopy(ISTANBUL_OPCODES) diff --git a/eth/vm/forks/muir_glacier/state.py b/eth/vm/forks/muir_glacier/state.py index a3a25cb764..c33e10dee2 100644 --- a/eth/vm/forks/muir_glacier/state.py +++ b/eth/vm/forks/muir_glacier/state.py @@ -1,8 +1,10 @@ from eth.vm.forks.istanbul.state import ( - IstanbulState + IstanbulState, ) -from .computation import MuirGlacierComputation +from .computation import ( + MuirGlacierComputation, +) class MuirGlacierState(IstanbulState): diff --git a/eth/vm/forks/muir_glacier/transactions.py b/eth/vm/forks/muir_glacier/transactions.py index ad3ed40c36..309f8e5a24 100644 --- a/eth/vm/forks/muir_glacier/transactions.py +++ b/eth/vm/forks/muir_glacier/transactions.py @@ -1,14 +1,17 @@ -from eth_keys.datatypes import PrivateKey -from eth_typing import Address - -from eth.vm.forks.istanbul.transactions import ( - IstanbulTransaction, - IstanbulUnsignedTransaction, +from eth_keys.datatypes import ( + PrivateKey, +) +from eth_typing import ( + Address, ) from eth._utils.transactions import ( create_transaction_signature, ) +from eth.vm.forks.istanbul.transactions import ( + IstanbulTransaction, + IstanbulUnsignedTransaction, +) class MuirGlacierTransaction(IstanbulTransaction): diff --git a/eth/vm/forks/paris/blocks.py b/eth/vm/forks/paris/blocks.py index 023ba5025b..f8ed63830c 100644 --- a/eth/vm/forks/paris/blocks.py +++ b/eth/vm/forks/paris/blocks.py @@ -1,27 +1,32 @@ -from abc import ABC -from typing import Type - -from eth.abc import TransactionBuilderAPI +from abc import ( + ABC, +) +from typing import ( + Type, +) from eth_utils import ( encode_hex, ) - from rlp.sedes import ( CountableList, ) -from .transactions import ( - ParisTransactionBuilder, +from eth.abc import ( + TransactionBuilderAPI, ) from eth.vm.forks.gray_glacier.blocks import ( GrayGlacierBlock, GrayGlacierBlockHeader, GrayGlacierMiningHeader, ) + from ..london.blocks import ( LondonBackwardsHeader, ) +from .transactions import ( + ParisTransactionBuilder, +) class ParisMiningHeader(GrayGlacierMiningHeader, ABC): diff --git a/eth/vm/forks/paris/computation.py b/eth/vm/forks/paris/computation.py index 21932300cd..7f98f3665b 100644 --- a/eth/vm/forks/paris/computation.py +++ b/eth/vm/forks/paris/computation.py @@ -1,5 +1,10 @@ -from .opcodes import PARIS_OPCODES -from eth.vm.forks.gray_glacier.computation import GrayGlacierComputation +from eth.vm.forks.gray_glacier.computation import ( + GrayGlacierComputation, +) + +from .opcodes import ( + PARIS_OPCODES, +) class ParisComputation(GrayGlacierComputation): diff --git a/eth/vm/forks/paris/headers.py b/eth/vm/forks/paris/headers.py index c9c8054f5c..b2cf7f4782 100644 --- a/eth/vm/forks/paris/headers.py +++ b/eth/vm/forks/paris/headers.py @@ -1,22 +1,34 @@ -from typing import Any, Optional +from typing import ( + Any, + Optional, +) -from toolz import curry +from eth_utils import ( + ValidationError, +) +from toolz import ( + curry, +) -from eth.abc import BlockHeaderAPI +from eth.abc import ( + BlockHeaderAPI, +) from eth.constants import ( POST_MERGE_DIFFICULTY, POST_MERGE_MIX_HASH, POST_MERGE_NONCE, ) +from eth.vm.forks.byzantium.headers import ( + configure_header, +) from eth.vm.forks.gray_glacier.headers import ( compute_gray_glacier_difficulty, create_gray_glacier_header_from_parent, ) -from eth.vm.forks.byzantium.headers import ( - configure_header, + +from .blocks import ( + ParisBlockHeader, ) -from eth_utils import ValidationError -from .blocks import ParisBlockHeader def _validate_and_return_paris_header_param( diff --git a/eth/vm/forks/paris/opcodes.py b/eth/vm/forks/paris/opcodes.py index a382909544..9a7595f008 100644 --- a/eth/vm/forks/paris/opcodes.py +++ b/eth/vm/forks/paris/opcodes.py @@ -1,19 +1,31 @@ import copy -from typing import Dict +from typing import ( + Dict, +) -from eth.vm.opcode import as_opcode -from eth_utils.toolz import merge +from eth_utils.toolz import ( + merge, +) -from eth import constants -from eth.abc import OpcodeAPI -from eth.vm import mnemonics -from eth.vm import opcode_values +from eth import ( + constants, +) +from eth.abc import ( + OpcodeAPI, +) +from eth.vm import ( + mnemonics, + opcode_values, +) +from eth.vm.forks.london.opcodes import ( + LONDON_OPCODES, +) from eth.vm.logic import ( block, ) - -from eth.vm.forks.london.opcodes import LONDON_OPCODES - +from eth.vm.opcode import ( + as_opcode, +) NEW_OPCODES = { # EIP-4399: supplant DIFFICULTY with PREVRANDAO diff --git a/eth/vm/forks/paris/state.py b/eth/vm/forks/paris/state.py index b7c5104877..08a2f6ff43 100644 --- a/eth/vm/forks/paris/state.py +++ b/eth/vm/forks/paris/state.py @@ -1,13 +1,25 @@ -from typing import Type +from typing import ( + Type, +) + +from eth_typing import ( + Hash32, +) from eth.abc import ( StateAPI, TransactionExecutorAPI, ) -from eth_typing import Hash32 -from .computation import ParisComputation -from ..gray_glacier import GrayGlacierState -from ..gray_glacier.state import GrayGlacierTransactionExecutor + +from ..gray_glacier import ( + GrayGlacierState, +) +from ..gray_glacier.state import ( + GrayGlacierTransactionExecutor, +) +from .computation import ( + ParisComputation, +) class ParisTransactionExecutor(GrayGlacierTransactionExecutor): diff --git a/eth/vm/forks/paris/transactions.py b/eth/vm/forks/paris/transactions.py index ace279910a..1f44b00ab5 100644 --- a/eth/vm/forks/paris/transactions.py +++ b/eth/vm/forks/paris/transactions.py @@ -1,6 +1,10 @@ -from abc import ABC +from abc import ( + ABC, +) -from eth_keys.datatypes import PrivateKey +from eth_keys.datatypes import ( + PrivateKey, +) from eth._utils.transactions import ( create_transaction_signature, diff --git a/eth/vm/forks/petersburg/blocks.py b/eth/vm/forks/petersburg/blocks.py index 4c244af159..da27af7bd6 100644 --- a/eth/vm/forks/petersburg/blocks.py +++ b/eth/vm/forks/petersburg/blocks.py @@ -1,6 +1,7 @@ from rlp.sedes import ( CountableList, ) + from eth.rlp.headers import ( BlockHeader, ) diff --git a/eth/vm/forks/petersburg/computation.py b/eth/vm/forks/petersburg/computation.py index f555cfc8d6..92973638aa 100644 --- a/eth/vm/forks/petersburg/computation.py +++ b/eth/vm/forks/petersburg/computation.py @@ -1,11 +1,11 @@ from eth.vm.forks.byzantium.computation import ( - BYZANTIUM_PRECOMPILES -) -from eth.vm.forks.byzantium.computation import ( - ByzantiumComputation + BYZANTIUM_PRECOMPILES, + ByzantiumComputation, ) -from .opcodes import PETERSBURG_OPCODES +from .opcodes import ( + PETERSBURG_OPCODES, +) PETERSBURG_PRECOMPILES = BYZANTIUM_PRECOMPILES diff --git a/eth/vm/forks/petersburg/constants.py b/eth/vm/forks/petersburg/constants.py index 0ba9138d13..bdfe5e9a19 100644 --- a/eth/vm/forks/petersburg/constants.py +++ b/eth/vm/forks/petersburg/constants.py @@ -1,5 +1,6 @@ -from eth_utils import denoms - +from eth_utils import ( + denoms, +) GAS_EXTCODEHASH_EIP1052 = 400 diff --git a/eth/vm/forks/petersburg/headers.py b/eth/vm/forks/petersburg/headers.py index d641b2bd0f..93df416568 100644 --- a/eth/vm/forks/petersburg/headers.py +++ b/eth/vm/forks/petersburg/headers.py @@ -1,10 +1,9 @@ from eth.vm.forks.byzantium.headers import ( + compute_difficulty, configure_header, create_header_from_parent, - compute_difficulty, ) - compute_petersburg_difficulty = compute_difficulty(5000000) create_petersburg_header_from_parent = create_header_from_parent( diff --git a/eth/vm/forks/petersburg/opcodes.py b/eth/vm/forks/petersburg/opcodes.py index dc26b9a62a..a5281ad0d4 100644 --- a/eth/vm/forks/petersburg/opcodes.py +++ b/eth/vm/forks/petersburg/opcodes.py @@ -1,14 +1,18 @@ import copy -from typing import Dict +from typing import ( + Dict, +) from eth_utils.toolz import ( - merge + merge, ) from eth import ( - constants + constants, +) +from eth.abc import ( + OpcodeAPI, ) -from eth.abc import OpcodeAPI from eth.vm import ( mnemonics, opcode_values, @@ -17,7 +21,7 @@ BYZANTIUM_OPCODES, ) from eth.vm.forks.petersburg.constants import ( - GAS_EXTCODEHASH_EIP1052 + GAS_EXTCODEHASH_EIP1052, ) from eth.vm.logic import ( arithmetic, @@ -25,10 +29,9 @@ system, ) from eth.vm.opcode import ( - as_opcode + as_opcode, ) - UPDATED_OPCODES = { opcode_values.SHL: as_opcode( logic_fn=arithmetic.shl, diff --git a/eth/vm/forks/petersburg/state.py b/eth/vm/forks/petersburg/state.py index 476e457083..3114e2e7f9 100644 --- a/eth/vm/forks/petersburg/state.py +++ b/eth/vm/forks/petersburg/state.py @@ -1,8 +1,10 @@ from eth.vm.forks.byzantium.state import ( - ByzantiumState + ByzantiumState, ) -from .computation import PetersburgComputation +from .computation import ( + PetersburgComputation, +) class PetersburgState(ByzantiumState): diff --git a/eth/vm/forks/petersburg/transactions.py b/eth/vm/forks/petersburg/transactions.py index ba299bb764..bf723d6f1f 100644 --- a/eth/vm/forks/petersburg/transactions.py +++ b/eth/vm/forks/petersburg/transactions.py @@ -1,14 +1,17 @@ -from eth_keys.datatypes import PrivateKey -from eth_typing import Address - -from eth.vm.forks.byzantium.transactions import ( - ByzantiumTransaction, - ByzantiumUnsignedTransaction, +from eth_keys.datatypes import ( + PrivateKey, +) +from eth_typing import ( + Address, ) from eth._utils.transactions import ( create_transaction_signature, ) +from eth.vm.forks.byzantium.transactions import ( + ByzantiumTransaction, + ByzantiumUnsignedTransaction, +) class PetersburgTransaction(ByzantiumTransaction): diff --git a/eth/vm/forks/shanghai/blocks.py b/eth/vm/forks/shanghai/blocks.py index 30df5e4ebe..7b369a76e9 100644 --- a/eth/vm/forks/shanghai/blocks.py +++ b/eth/vm/forks/shanghai/blocks.py @@ -1,47 +1,86 @@ -from abc import ABC -from typing import List, Sequence, Tuple, Type, cast +from abc import ( + ABC, +) +from typing import ( + List, + Sequence, + Tuple, + Type, + cast, +) +from eth_bloom import ( + BloomFilter, +) +from eth_typing import ( + Address, + BlockNumber, + Hash32, +) +from eth_utils import ( + encode_hex, + keccak, +) import rlp -from eth.exceptions import BlockNotFound, HeaderNotFound -from eth.rlp.blocks import BaseBlock -from eth.rlp.headers import BlockHeader -from eth.rlp.sedes import address, hash32, trie_root, uint256 -from eth_bloom import BloomFilter -from eth_typing import Address, BlockNumber, Hash32 - -from eth._utils.headers import new_timestamp_from_parent +from rlp.sedes import ( + Binary, + CountableList, + big_endian_int, + binary, +) +from trie.exceptions import ( + MissingTrieNode, +) + +from eth._utils.headers import ( + new_timestamp_from_parent, +) from eth.abc import ( - BlockHeaderAPI, BlockHeaderSedesAPI, ChainDatabaseAPI, MiningHeaderAPI, - ReceiptAPI, ReceiptBuilderAPI, SignedTransactionAPI, TransactionBuilderAPI, + BlockHeaderAPI, + BlockHeaderSedesAPI, + ChainDatabaseAPI, + MiningHeaderAPI, + ReceiptAPI, + ReceiptBuilderAPI, + SignedTransactionAPI, + TransactionBuilderAPI, WithdrawalAPI, ) from eth.constants import ( - ZERO_ADDRESS, - ZERO_HASH32, + BLANK_ROOT_HASH, EMPTY_UNCLE_HASH, GENESIS_NONCE, GENESIS_PARENT_HASH, - BLANK_ROOT_HASH, + ZERO_ADDRESS, + ZERO_HASH32, ) - -from eth_utils import ( - encode_hex, keccak, +from eth.exceptions import ( + BlockNotFound, + HeaderNotFound, ) - -from rlp.sedes import ( - Binary, CountableList, big_endian_int, binary, +from eth.rlp.blocks import ( + BaseBlock, +) +from eth.rlp.headers import ( + BlockHeader, +) +from eth.rlp.sedes import ( + address, + hash32, + trie_root, + uint256, ) -from trie.exceptions import MissingTrieNode +from ..london.blocks import ( + LondonBlockHeader, +) from .transactions import ( ShanghaiTransactionBuilder, ) -from .withdrawals import Withdrawal -from ..london.blocks import ( - LondonBlockHeader, +from .withdrawals import ( + Withdrawal, ) - UNMINED_SHANGHAI_HEADER_FIELDS = [ ('parent_hash', hash32), ('uncles_hash', hash32), diff --git a/eth/vm/forks/shanghai/computation.py b/eth/vm/forks/shanghai/computation.py index 0937afcb7e..26a9470715 100644 --- a/eth/vm/forks/shanghai/computation.py +++ b/eth/vm/forks/shanghai/computation.py @@ -1,14 +1,26 @@ -from eth._utils.numeric import ceil32 -from eth.abc import ComputationAPI, MessageAPI, StateAPI, TransactionContextAPI +from eth._utils.numeric import ( + ceil32, +) +from eth.abc import ( + ComputationAPI, + MessageAPI, + StateAPI, + TransactionContextAPI, +) +from eth.exceptions import ( + OutOfGas, +) +from eth.vm.forks.paris.computation import ( + ParisComputation, +) + from .constants import ( INITCODE_WORD_COST, MAX_INITCODE_SIZE, ) -from .opcodes import SHANGHAI_OPCODES -from eth.exceptions import ( - OutOfGas, +from .opcodes import ( + SHANGHAI_OPCODES, ) -from eth.vm.forks.paris.computation import ParisComputation class ShanghaiComputation(ParisComputation): diff --git a/eth/vm/forks/shanghai/constants.py b/eth/vm/forks/shanghai/constants.py index 41bb499491..916f807540 100644 --- a/eth/vm/forks/shanghai/constants.py +++ b/eth/vm/forks/shanghai/constants.py @@ -1,4 +1,6 @@ -from eth.vm.forks.spurious_dragon.constants import EIP170_CODE_SIZE_LIMIT +from eth.vm.forks.spurious_dragon.constants import ( + EIP170_CODE_SIZE_LIMIT, +) # https://eips.ethereum.org/EIPS/eip-3860 INITCODE_WORD_COST = 2 diff --git a/eth/vm/forks/shanghai/headers.py b/eth/vm/forks/shanghai/headers.py index d4234143c4..6c03fc76d1 100644 --- a/eth/vm/forks/shanghai/headers.py +++ b/eth/vm/forks/shanghai/headers.py @@ -1,15 +1,25 @@ -from typing import Any, Optional +from typing import ( + Any, + Optional, +) -from toolz import curry +from toolz import ( + curry, +) -from eth.abc import BlockHeaderAPI -from eth.vm.forks.paris.headers import ( - create_paris_header_from_parent, +from eth.abc import ( + BlockHeaderAPI, ) from eth.vm.forks.byzantium.headers import ( configure_header, ) -from .blocks import ShanghaiBlockHeader +from eth.vm.forks.paris.headers import ( + create_paris_header_from_parent, +) + +from .blocks import ( + ShanghaiBlockHeader, +) @curry diff --git a/eth/vm/forks/shanghai/logic.py b/eth/vm/forks/shanghai/logic.py index 8dcab5edea..a627baa637 100644 --- a/eth/vm/forks/shanghai/logic.py +++ b/eth/vm/forks/shanghai/logic.py @@ -1,17 +1,18 @@ -from .constants import ( - INITCODE_WORD_COST, -) from eth._utils.numeric import ( ceil32, ) from eth.vm.forks.berlin.logic import ( - CreateEIP2929, Create2EIP2929, + CreateEIP2929, ) from eth.vm.logic.system import ( CreateOpcodeStackData, ) +from .constants import ( + INITCODE_WORD_COST, +) + class CreateEIP3860(CreateEIP2929): def get_gas_cost(self, data: CreateOpcodeStackData) -> int: diff --git a/eth/vm/forks/shanghai/opcodes.py b/eth/vm/forks/shanghai/opcodes.py index e6209c0912..bc757f7abf 100644 --- a/eth/vm/forks/shanghai/opcodes.py +++ b/eth/vm/forks/shanghai/opcodes.py @@ -1,24 +1,39 @@ import copy -from typing import Dict +from typing import ( + Dict, +) -from .logic import ( - CreateEIP3860, - Create2EIP3860, +from eth_utils.toolz import ( + merge, ) -from eth.tools._utils.deprecation import deprecate_method -from eth.vm.opcode import as_opcode -from eth_utils.toolz import merge -from eth import constants -from eth.abc import OpcodeAPI -from eth.vm import mnemonics -from eth.vm import opcode_values +from eth import ( + constants, +) +from eth.abc import ( + OpcodeAPI, +) +from eth.tools._utils.deprecation import ( + deprecate_method, +) +from eth.vm import ( + mnemonics, + opcode_values, +) +from eth.vm.forks.paris.opcodes import ( + PARIS_OPCODES, +) from eth.vm.logic import ( stack, ) +from eth.vm.opcode import ( + as_opcode, +) -from eth.vm.forks.paris.opcodes import PARIS_OPCODES - +from .logic import ( + Create2EIP3860, + CreateEIP3860, +) UPDATED_OPCODES: Dict[int, OpcodeAPI] = { opcode_values.CREATE: CreateEIP3860.configure( diff --git a/eth/vm/forks/shanghai/state.py b/eth/vm/forks/shanghai/state.py index 05e728f7ce..7f59abb82b 100644 --- a/eth/vm/forks/shanghai/state.py +++ b/eth/vm/forks/shanghai/state.py @@ -1,12 +1,21 @@ -from typing import Type +from typing import ( + Type, +) from eth.abc import ( TransactionExecutorAPI, WithdrawalAPI, ) -from .computation import ShanghaiComputation -from ..paris import ParisState -from ..paris.state import ParisTransactionExecutor + +from ..paris import ( + ParisState, +) +from ..paris.state import ( + ParisTransactionExecutor, +) +from .computation import ( + ShanghaiComputation, +) class ShanghaiTransactionExecutor(ParisTransactionExecutor): diff --git a/eth/vm/forks/shanghai/transactions.py b/eth/vm/forks/shanghai/transactions.py index 79e48ff9b3..bc320aeae7 100644 --- a/eth/vm/forks/shanghai/transactions.py +++ b/eth/vm/forks/shanghai/transactions.py @@ -1,6 +1,10 @@ -from abc import ABC +from abc import ( + ABC, +) -from eth_keys.datatypes import PrivateKey +from eth_keys.datatypes import ( + PrivateKey, +) from eth._utils.transactions import ( create_transaction_signature, diff --git a/eth/vm/forks/shanghai/withdrawals.py b/eth/vm/forks/shanghai/withdrawals.py index 4161af8b8b..b0dedac734 100644 --- a/eth/vm/forks/shanghai/withdrawals.py +++ b/eth/vm/forks/shanghai/withdrawals.py @@ -1,20 +1,32 @@ -from cached_property import cached_property -from typing import cast +from typing import ( + cast, +) -from eth.abc import WithdrawalAPI -from eth.validation import ( - validate_canonical_address, - validate_uint64, +from cached_property import ( + cached_property, ) from eth_typing import ( Address, Hash32, ) - +from eth_utils import ( + keccak, +) import rlp -from eth.rlp.sedes import address -from eth_utils import keccak -from rlp.sedes import big_endian_int +from rlp.sedes import ( + big_endian_int, +) + +from eth.abc import ( + WithdrawalAPI, +) +from eth.rlp.sedes import ( + address, +) +from eth.validation import ( + validate_canonical_address, + validate_uint64, +) class Withdrawal(rlp.Serializable): diff --git a/eth/vm/forks/spurious_dragon/_utils.py b/eth/vm/forks/spurious_dragon/_utils.py index 35fd999ffa..bbf2b72a9d 100644 --- a/eth/vm/forks/spurious_dragon/_utils.py +++ b/eth/vm/forks/spurious_dragon/_utils.py @@ -1,17 +1,23 @@ -from typing import Iterable - -from eth_typing import Address - -from eth_utils import to_set +from typing import ( + Iterable, +) -from eth import constants +from eth_typing import ( + Address, +) +from eth_utils import ( + to_set, +) +from eth import ( + constants, +) from eth._utils.address import ( force_bytes_to_address, ) - -from eth.vm.computation import BaseComputation - +from eth.vm.computation import ( + BaseComputation, +) THREE = force_bytes_to_address(b'\x03') diff --git a/eth/vm/forks/spurious_dragon/blocks.py b/eth/vm/forks/spurious_dragon/blocks.py index fe9371d1e5..d11d95bc94 100644 --- a/eth/vm/forks/spurious_dragon/blocks.py +++ b/eth/vm/forks/spurious_dragon/blocks.py @@ -1,12 +1,14 @@ from rlp.sedes import ( CountableList, ) + from eth.rlp.headers import ( BlockHeader, ) from eth.vm.forks.homestead.blocks import ( HomesteadBlock, ) + from .transactions import ( SpuriousDragonTransaction, ) diff --git a/eth/vm/forks/spurious_dragon/computation.py b/eth/vm/forks/spurious_dragon/computation.py index bfa863e08b..a3609f3d03 100644 --- a/eth/vm/forks/spurious_dragon/computation.py +++ b/eth/vm/forks/spurious_dragon/computation.py @@ -1,10 +1,13 @@ -from eth_hash.auto import keccak - +from eth_hash.auto import ( + keccak, +) from eth_utils import ( encode_hex, ) -from eth import constants +from eth import ( + constants, +) from eth.abc import ( ComputationAPI, MessageAPI, @@ -19,8 +22,12 @@ HomesteadComputation, ) -from ..spurious_dragon.constants import EIP170_CODE_SIZE_LIMIT -from .opcodes import SPURIOUS_DRAGON_OPCODES +from ..spurious_dragon.constants import ( + EIP170_CODE_SIZE_LIMIT, +) +from .opcodes import ( + SPURIOUS_DRAGON_OPCODES, +) class SpuriousDragonComputation(HomesteadComputation): diff --git a/eth/vm/forks/spurious_dragon/opcodes.py b/eth/vm/forks/spurious_dragon/opcodes.py index eed5820eda..0ce713a539 100644 --- a/eth/vm/forks/spurious_dragon/opcodes.py +++ b/eth/vm/forks/spurious_dragon/opcodes.py @@ -1,29 +1,40 @@ import copy -from typing import Dict +from typing import ( + Dict, +) -from eth_utils.toolz import merge +from eth_utils.toolz import ( + merge, +) -from eth.abc import OpcodeAPI +from eth.abc import ( + OpcodeAPI, +) +from eth.vm import ( + mnemonics, + opcode_values, +) from eth.vm.forks.tangerine_whistle.constants import ( + GAS_CALL_EIP150, GAS_SELFDESTRUCT_EIP150, - GAS_CALL_EIP150 ) -from eth.vm import mnemonics -from eth.vm import opcode_values -from eth.vm.forks.tangerine_whistle.opcodes import TANGERINE_WHISTLE_OPCODES +from eth.vm.forks.tangerine_whistle.opcodes import ( + TANGERINE_WHISTLE_OPCODES, +) from eth.vm.logic import ( arithmetic, - system, call, + system, +) +from eth.vm.opcode import ( + as_opcode, ) -from eth.vm.opcode import as_opcode from .constants import ( GAS_EXP_EIP160, - GAS_EXPBYTE_EIP160 + GAS_EXPBYTE_EIP160, ) - UPDATED_OPCODES = { opcode_values.EXP: as_opcode( logic_fn=arithmetic.exp(gas_per_byte=GAS_EXPBYTE_EIP160), diff --git a/eth/vm/forks/spurious_dragon/state.py b/eth/vm/forks/spurious_dragon/state.py index 802278b595..ae02650920 100644 --- a/eth/vm/forks/spurious_dragon/state.py +++ b/eth/vm/forks/spurious_dragon/state.py @@ -1,4 +1,6 @@ -from typing import Type +from typing import ( + Type, +) from eth_utils import ( encode_hex, @@ -14,8 +16,12 @@ HomesteadTransactionExecutor, ) -from .computation import SpuriousDragonComputation -from ._utils import collect_touched_accounts +from ._utils import ( + collect_touched_accounts, +) +from .computation import ( + SpuriousDragonComputation, +) class SpuriousDragonTransactionExecutor(HomesteadTransactionExecutor): diff --git a/eth/vm/forks/spurious_dragon/transactions.py b/eth/vm/forks/spurious_dragon/transactions.py index 394bcdf916..55761e6b70 100644 --- a/eth/vm/forks/spurious_dragon/transactions.py +++ b/eth/vm/forks/spurious_dragon/transactions.py @@ -1,28 +1,30 @@ -from typing import Optional - -from eth_keys.datatypes import PrivateKey +from typing import ( + Optional, +) +from eth_keys.datatypes import ( + PrivateKey, +) from eth_typing import ( Address, ) - from eth_utils import ( int_to_big_endian, ) - import rlp -from eth.vm.forks.homestead.transactions import ( - HomesteadTransaction, - HomesteadUnsignedTransaction, +from eth._utils.numeric import ( + is_even, ) - -from eth._utils.numeric import is_even from eth._utils.transactions import ( create_transaction_signature, extract_chain_id, is_eip_155_signed_transaction, ) +from eth.vm.forks.homestead.transactions import ( + HomesteadTransaction, + HomesteadUnsignedTransaction, +) class SpuriousDragonTransaction(HomesteadTransaction): diff --git a/eth/vm/forks/tangerine_whistle/computation.py b/eth/vm/forks/tangerine_whistle/computation.py index 22916d3202..b9e6467fa5 100644 --- a/eth/vm/forks/tangerine_whistle/computation.py +++ b/eth/vm/forks/tangerine_whistle/computation.py @@ -1,6 +1,9 @@ -from ..homestead.computation import HomesteadComputation - -from .opcodes import TANGERINE_WHISTLE_OPCODES +from ..homestead.computation import ( + HomesteadComputation, +) +from .opcodes import ( + TANGERINE_WHISTLE_OPCODES, +) class TangerineWhistleComputation(HomesteadComputation): diff --git a/eth/vm/forks/tangerine_whistle/opcodes.py b/eth/vm/forks/tangerine_whistle/opcodes.py index c4f158f9ff..64d8da9645 100644 --- a/eth/vm/forks/tangerine_whistle/opcodes.py +++ b/eth/vm/forks/tangerine_whistle/opcodes.py @@ -1,20 +1,31 @@ import copy -from eth_utils.toolz import merge +from eth_utils.toolz import ( + merge, +) -from eth.vm.forks.tangerine_whistle import constants -from eth.constants import GAS_CREATE -from eth.vm import opcode_values -from eth.vm import mnemonics -from eth.vm.forks.homestead.opcodes import HOMESTEAD_OPCODES +from eth.constants import ( + GAS_CREATE, +) +from eth.vm import ( + mnemonics, + opcode_values, +) +from eth.vm.forks.homestead.opcodes import ( + HOMESTEAD_OPCODES, +) +from eth.vm.forks.tangerine_whistle import ( + constants, +) from eth.vm.logic import ( call, context, storage, system, ) -from eth.vm.opcode import as_opcode - +from eth.vm.opcode import ( + as_opcode, +) UPDATED_OPCODES = { opcode_values.EXTCODESIZE: as_opcode( diff --git a/eth/vm/forks/tangerine_whistle/state.py b/eth/vm/forks/tangerine_whistle/state.py index 4c8715d27a..101ff5e62c 100644 --- a/eth/vm/forks/tangerine_whistle/state.py +++ b/eth/vm/forks/tangerine_whistle/state.py @@ -1,6 +1,10 @@ -from eth.vm.forks.homestead.state import HomesteadState +from eth.vm.forks.homestead.state import ( + HomesteadState, +) -from .computation import TangerineWhistleComputation +from .computation import ( + TangerineWhistleComputation, +) class TangerineWhistleState(HomesteadState): diff --git a/eth/vm/gas_meter.py b/eth/vm/gas_meter.py index ea9a30f218..0d6e6780e4 100644 --- a/eth/vm/gas_meter.py +++ b/eth/vm/gas_meter.py @@ -1,12 +1,15 @@ from typing import ( Callable, ) + from eth_utils import ( ValidationError, get_extended_debug_logger, ) -from eth.abc import GasMeterAPI +from eth.abc import ( + GasMeterAPI, +) from eth.exceptions import ( OutOfGas, ) diff --git a/eth/vm/header.py b/eth/vm/header.py index 09222db60d..1f0071e1e8 100644 --- a/eth/vm/header.py +++ b/eth/vm/header.py @@ -1,4 +1,6 @@ -from eth.vm.forks.shanghai.blocks import ShanghaiBackwardsHeader +from eth.vm.forks.shanghai.blocks import ( + ShanghaiBackwardsHeader, +) HeaderSedes = ShanghaiBackwardsHeader """ diff --git a/eth/vm/logic/arithmetic.py b/eth/vm/logic/arithmetic.py index 07d46b80ec..f52cc10847 100644 --- a/eth/vm/logic/arithmetic.py +++ b/eth/vm/logic/arithmetic.py @@ -2,15 +2,17 @@ curry, ) -from eth import constants - +from eth import ( + constants, +) from eth._utils.numeric import ( - unsigned_to_signed, - signed_to_unsigned, ceil8, + signed_to_unsigned, + unsigned_to_signed, +) +from eth.vm.computation import ( + BaseComputation, ) - -from eth.vm.computation import BaseComputation def add(computation: BaseComputation) -> None: diff --git a/eth/vm/logic/block.py b/eth/vm/logic/block.py index be97c0a270..b5395b439b 100644 --- a/eth/vm/logic/block.py +++ b/eth/vm/logic/block.py @@ -1,4 +1,6 @@ -from eth.vm.computation import BaseComputation +from eth.vm.computation import ( + BaseComputation, +) def blockhash(computation: BaseComputation) -> None: diff --git a/eth/vm/logic/call.py b/eth/vm/logic/call.py index 5d8c4294a9..5c8e3ff15c 100644 --- a/eth/vm/logic/call.py +++ b/eth/vm/logic/call.py @@ -1,18 +1,21 @@ from abc import ( ABC, - abstractmethod + abstractmethod, ) - from typing import ( Tuple, ) -from eth import constants - from eth_typing import ( Address, ) +from eth import ( + constants, +) +from eth._utils.address import ( + force_bytes_to_address, +) from eth.abc import ( ComputationAPI, ) @@ -24,11 +27,6 @@ Opcode, ) -from eth._utils.address import ( - force_bytes_to_address, -) - - CallParams = Tuple[int, int, Address, Address, Address, int, int, int, int, bool, bool] diff --git a/eth/vm/logic/comparison.py b/eth/vm/logic/comparison.py index 19eafa2548..cd4a1f0d0f 100644 --- a/eth/vm/logic/comparison.py +++ b/eth/vm/logic/comparison.py @@ -1,11 +1,13 @@ -from eth import constants - +from eth import ( + constants, +) from eth._utils.numeric import ( signed_to_unsigned, unsigned_to_signed, ) - -from eth.vm.computation import BaseComputation +from eth.vm.computation import ( + BaseComputation, +) def lt(computation: BaseComputation) -> None: diff --git a/eth/vm/logic/context.py b/eth/vm/logic/context.py index a0ebee7830..978a7b9310 100644 --- a/eth/vm/logic/context.py +++ b/eth/vm/logic/context.py @@ -1,26 +1,29 @@ -from typing import Tuple +from typing import ( + Tuple, +) from eth_typing import ( Address, ) -from eth import constants - -from eth.abc import ( - ComputationAPI, +from eth import ( + constants, ) -from eth.exceptions import ( - OutOfBoundsRead, -) - from eth._utils.address import ( force_bytes_to_address, ) from eth._utils.numeric import ( ceil32, ) - -from eth.vm.computation import BaseComputation +from eth.abc import ( + ComputationAPI, +) +from eth.exceptions import ( + OutOfBoundsRead, +) +from eth.vm.computation import ( + BaseComputation, +) def balance(computation: BaseComputation) -> None: diff --git a/eth/vm/logic/duplication.py b/eth/vm/logic/duplication.py index 4d4b75eb27..eb5319df50 100644 --- a/eth/vm/logic/duplication.py +++ b/eth/vm/logic/duplication.py @@ -1,6 +1,8 @@ import functools -from eth.vm.computation import BaseComputation +from eth.vm.computation import ( + BaseComputation, +) def dup_XX(computation: BaseComputation, position: int) -> None: diff --git a/eth/vm/logic/flow.py b/eth/vm/logic/flow.py index 47fc7a15ad..dbbea58069 100644 --- a/eth/vm/logic/flow.py +++ b/eth/vm/logic/flow.py @@ -1,10 +1,11 @@ from eth.exceptions import ( - InvalidJumpDestination, - InvalidInstruction, Halt, + InvalidInstruction, + InvalidJumpDestination, +) +from eth.vm.computation import ( + BaseComputation, ) - -from eth.vm.computation import BaseComputation from eth.vm.opcode_values import ( JUMPDEST, ) diff --git a/eth/vm/logic/invalid.py b/eth/vm/logic/invalid.py index 462b6ac8e7..e58f81e6ac 100644 --- a/eth/vm/logic/invalid.py +++ b/eth/vm/logic/invalid.py @@ -1,6 +1,12 @@ -from eth.abc import ComputationAPI -from eth.exceptions import InvalidInstruction -from eth.vm.opcode import Opcode +from eth.abc import ( + ComputationAPI, +) +from eth.exceptions import ( + InvalidInstruction, +) +from eth.vm.opcode import ( + Opcode, +) class InvalidOpcode(Opcode): diff --git a/eth/vm/logic/logging.py b/eth/vm/logic/logging.py index cfd881d437..745b8ea22a 100644 --- a/eth/vm/logic/logging.py +++ b/eth/vm/logic/logging.py @@ -1,8 +1,14 @@ import functools -from typing import Tuple -from eth import constants - -from eth.vm.computation import BaseComputation +from typing import ( + Tuple, +) + +from eth import ( + constants, +) +from eth.vm.computation import ( + BaseComputation, +) def log_XX(computation: BaseComputation, topic_count: int) -> None: diff --git a/eth/vm/logic/memory.py b/eth/vm/logic/memory.py index 696693d449..eaa8f917b7 100644 --- a/eth/vm/logic/memory.py +++ b/eth/vm/logic/memory.py @@ -1,4 +1,6 @@ -from eth.vm.computation import BaseComputation +from eth.vm.computation import ( + BaseComputation, +) def mstore(computation: BaseComputation) -> None: diff --git a/eth/vm/logic/sha3.py b/eth/vm/logic/sha3.py index 6c79fad934..13f08c819a 100644 --- a/eth/vm/logic/sha3.py +++ b/eth/vm/logic/sha3.py @@ -1,10 +1,16 @@ -from eth_hash.auto import keccak +from eth_hash.auto import ( + keccak, +) -from eth import constants +from eth import ( + constants, +) from eth._utils.numeric import ( ceil32, ) -from eth.vm.computation import BaseComputation +from eth.vm.computation import ( + BaseComputation, +) def sha3(computation: BaseComputation) -> None: diff --git a/eth/vm/logic/stack.py b/eth/vm/logic/stack.py index 2a995c12cf..9ea0ab8149 100644 --- a/eth/vm/logic/stack.py +++ b/eth/vm/logic/stack.py @@ -1,6 +1,8 @@ import functools -from eth.vm.computation import BaseComputation +from eth.vm.computation import ( + BaseComputation, +) def pop(computation: BaseComputation) -> None: diff --git a/eth/vm/logic/storage.py b/eth/vm/logic/storage.py index 47bf2cb74d..154197d8fb 100644 --- a/eth/vm/logic/storage.py +++ b/eth/vm/logic/storage.py @@ -1,11 +1,17 @@ -from typing import NamedTuple +from typing import ( + NamedTuple, +) from eth_utils import ( encode_hex, ) -from eth import constants -from eth.vm.computation import BaseComputation +from eth import ( + constants, +) +from eth.vm.computation import ( + BaseComputation, +) def sstore(computation: BaseComputation) -> None: diff --git a/eth/vm/logic/swap.py b/eth/vm/logic/swap.py index b2b75d0c1a..91c88db600 100644 --- a/eth/vm/logic/swap.py +++ b/eth/vm/logic/swap.py @@ -1,6 +1,8 @@ import functools -from eth.vm.computation import BaseComputation +from eth.vm.computation import ( + BaseComputation, +) def swap_XX(computation: BaseComputation, position: int) -> None: diff --git a/eth/vm/logic/system.py b/eth/vm/logic/system.py index 214346f49b..983b27bd13 100644 --- a/eth/vm/logic/system.py +++ b/eth/vm/logic/system.py @@ -4,13 +4,10 @@ from eth_utils import ( encode_hex, ) -from eth import constants -from eth.exceptions import ( - Halt, - Revert, - WriteProtection, -) +from eth import ( + constants, +) from eth._utils.address import ( force_bytes_to_address, generate_contract_address, @@ -23,10 +20,21 @@ ComputationAPI, MessageAPI, ) -from eth.vm import mnemonics -from eth.vm.opcode import Opcode +from eth.exceptions import ( + Halt, + Revert, + WriteProtection, +) +from eth.vm import ( + mnemonics, +) +from eth.vm.opcode import ( + Opcode, +) -from .call import max_child_gas_eip150 +from .call import ( + max_child_gas_eip150, +) def return_op(computation: ComputationAPI) -> None: diff --git a/eth/vm/memory.py b/eth/vm/memory.py index cff7f2836e..074817eadf 100644 --- a/eth/vm/memory.py +++ b/eth/vm/memory.py @@ -1,6 +1,12 @@ import itertools import logging +from eth._utils.numeric import ( + ceil32, +) +from eth.abc import ( + MemoryAPI, +) from eth.validation import ( validate_is_bytes, validate_length, @@ -8,11 +14,6 @@ validate_uint256, ) -from eth._utils.numeric import ( - ceil32, -) -from eth.abc import MemoryAPI - class Memory(MemoryAPI): __slots__ = ['_bytes'] diff --git a/eth/vm/message.py b/eth/vm/message.py index f746566e66..ee2f0bc435 100644 --- a/eth/vm/message.py +++ b/eth/vm/message.py @@ -1,8 +1,12 @@ import logging -from eth_typing import Address +from eth_typing import ( + Address, +) -from eth.abc import MessageAPI +from eth.abc import ( + MessageAPI, +) from eth.constants import ( CREATE_CONTRACT_ADDRESS, ) @@ -11,12 +15,12 @@ ) from eth.validation import ( validate_canonical_address, + validate_gte, + validate_is_boolean, validate_is_bytes, validate_is_bytes_or_view, validate_is_integer, - validate_gte, validate_uint256, - validate_is_boolean, ) diff --git a/eth/vm/opcode.py b/eth/vm/opcode.py index 5232f45555..5ce7d8de3f 100644 --- a/eth/vm/opcode.py +++ b/eth/vm/opcode.py @@ -1,5 +1,4 @@ import functools - from typing import ( Any, Callable, @@ -12,13 +11,14 @@ get_extended_debug_logger, ) -from eth._utils.datatypes import Configurable +from eth._utils.datatypes import ( + Configurable, +) from eth.abc import ( ComputationAPI, OpcodeAPI, ) - T = TypeVar('T') diff --git a/eth/vm/spoof.py b/eth/vm/spoof.py index 1c81eec130..40d27cc0ff 100644 --- a/eth/vm/spoof.py +++ b/eth/vm/spoof.py @@ -1,7 +1,15 @@ -from typing import Any, Union +from typing import ( + Any, + Union, +) -from eth.abc import SignedTransactionAPI, UnsignedTransactionAPI -from eth._utils.spoof import SpoofAttributes +from eth._utils.spoof import ( + SpoofAttributes, +) +from eth.abc import ( + SignedTransactionAPI, + UnsignedTransactionAPI, +) class SpoofTransaction(SpoofAttributes): diff --git a/eth/vm/stack.py b/eth/vm/stack.py index d9be86ce27..74f21ceaa7 100644 --- a/eth/vm/stack.py +++ b/eth/vm/stack.py @@ -3,7 +3,7 @@ Iterable, List, Tuple, - Union + Union, ) from eth_utils import ( @@ -11,17 +11,19 @@ big_endian_to_int, int_to_big_endian, ) + +from eth.abc import ( + StackAPI, +) from eth.exceptions import ( - InsufficientStack, FullStack, + InsufficientStack, ) from eth.validation import ( validate_stack_bytes, validate_stack_int, ) -from eth.abc import StackAPI - def _busted_type(item_type: type, value: Union[int, bytes]) -> ValidationError: return ValidationError( diff --git a/eth/vm/state.py b/eth/vm/state.py index e3f987fbb8..1f38540d26 100644 --- a/eth/vm/state.py +++ b/eth/vm/state.py @@ -15,27 +15,31 @@ ExtendedDebugLogger, get_extended_debug_logger, ) -from eth_utils.toolz import nth +from eth_utils.toolz import ( + nth, +) +from eth._utils.datatypes import ( + Configurable, +) from eth.abc import ( AccountDatabaseAPI, AtomicDatabaseAPI, ComputationAPI, ExecutionContextAPI, MessageAPI, + MetaWitnessAPI, SignedTransactionAPI, StateAPI, TransactionContextAPI, TransactionExecutorAPI, - MetaWitnessAPI, WithdrawalAPI, ) from eth.constants import ( MAX_PREV_HEADER_DEPTH, ) -from eth.typing import JournalDBCheckpoint -from eth._utils.datatypes import ( - Configurable, +from eth.typing import ( + JournalDBCheckpoint, ) diff --git a/eth/vm/transaction_context.py b/eth/vm/transaction_context.py index c4a12fa9dc..c73e0bd9c6 100644 --- a/eth/vm/transaction_context.py +++ b/eth/vm/transaction_context.py @@ -1,8 +1,12 @@ import itertools -from eth_typing import Address +from eth_typing import ( + Address, +) -from eth.abc import TransactionContextAPI +from eth.abc import ( + TransactionContextAPI, +) from eth.validation import ( validate_canonical_address, validate_uint256, diff --git a/tox.ini b/tox.ini index 8c6e696540..885e5eab01 100644 --- a/tox.ini +++ b/tox.ini @@ -60,6 +60,7 @@ deps: .[eth,lint] commands: flake8 {toxinidir}/eth {toxinidir}/tests {toxinidir}/scripts mypy -p eth --config-file {toxinidir}/mypy.ini + isort --check-only --diff {toxinidir}/eth/ {toxinidir}/scripts/ {toxinidir}/tests/ [testenv:lint] basepython: python