eth-hash0.7.0
Published
eth-hash: The Ethereum hashing function, keccak256, sometimes (erroneously) called sha3
pip install eth-hash
Package Downloads
Authors
Project URLs
Requires Python
>=3.8, <4
Dependencies
- build
>=0.9.0 ; extra == 'dev'
- bumpversion
>=0.5.3 ; extra == 'dev'
- ipython
; extra == 'dev'
- pre-commit
>=3.4.0 ; extra == 'dev'
- tox
>=4.0.0 ; extra == 'dev'
- twine
; extra == 'dev'
- wheel
; extra == 'dev'
- sphinx
>=6.0.0 ; extra == 'dev'
- sphinx-rtd-theme
>=1.0.0 ; extra == 'dev'
- towncrier
<22,>=21 ; extra == 'dev'
- pytest
>=7.0.0 ; extra == 'dev'
- pytest-xdist
>=2.4.0 ; extra == 'dev'
- sphinx
>=6.0.0 ; extra == 'docs'
- sphinx-rtd-theme
>=1.0.0 ; extra == 'docs'
- towncrier
<22,>=21 ; extra == 'docs'
- pycryptodome
<4,>=3.6.6 ; extra == 'pycryptodome'
- pysha3
<2.0.0,>=1.0.0 ; (python_version < "3.9") and extra == 'pysha3'
- safe-pysha3
>=1.0.0 ; (python_version >= "3.9") and extra == 'pysha3'
- pytest
>=7.0.0 ; extra == 'test'
- pytest-xdist
>=2.4.0 ; extra == 'test'
eth-hash
The Ethereum hashing function, keccak256, sometimes (erroneously) called sha3
Note: the similarly named pyethash has a completely different use: it generates proofs of work.
This is a low-level library, intended to be used internally by other Ethereum tools.
If you're looking for a convenient hashing tool, check out
eth_utils.keccak()
which will be a little friendlier, and provide access to other helpful utilities.
Read more in the documentation on ReadTheDocs. View the change log.
Quickstart
python -m pip install "eth-hash[pycryptodome]"
>>> from eth_hash.auto import keccak
>>> keccak(b'')
b"\xc5\xd2F\x01\x86\xf7#<\x92~}\xb2\xdc\xc7\x03\xc0\xe5\x00\xb6S\xca\x82';{\xfa\xd8\x04]\x85\xa4p"
See the docs for more about choosing and installing backends.
Developer Setup
If you would like to hack on eth-hash, please check out the Snake Charmers Tactical Manual for information on how we do:
- Testing
- Pull Requests
- Documentation
We use pre-commit to maintain consistent code style. Once
installed, it will run automatically with every commit. You can also run it manually
with make lint
. If you need to make a commit that skips the pre-commit
checks, you
can do so with git commit --no-verify
.
Development Environment Setup
You can set up your dev environment with:
git clone [email protected]:ethereum/eth-hash.git
cd eth-hash
python -m virtualenv venv
. venv/bin/activate
python -m pip install -e ".[dev]"
pre-commit install
Release setup
To release a new version:
make release bump=$$VERSION_PART_TO_BUMP$$
How to bumpversion
The version format for this repo is {major}.{minor}.{patch}
for stable, and
{major}.{minor}.{patch}-{stage}.{devnum}
for unstable (stage
can be alpha or beta).
To issue the next version in line, specify which part to bump,
like make release bump=minor
or make release bump=devnum
. This is typically done from the
master branch, except when releasing a beta (in which case the beta is released from master,
and the previous stable branch is released from said branch).
If you are in a beta version, make release bump=stage
will switch to a stable.
To issue an unstable version when the current version is stable, specify the
new version explicitly, like make release bump="--new-version 4.0.0-alpha.1 devnum"