Common utilities for Ethereum https://nimbus.status.im
Go to file
Kim De Mey d7577f59d7
Rework of ENR decoding code (#709)
- Rework to have exception raise only at rlp decoding and use
result types from then onwards
- Adjust the current API to have result versions and deprecated
the ones which had var Record + bool
- Add PublickKey to the Record object, as this allows us to skip
fromRaw calls whenever access is needed to the public key
- Add a TypedRecord.fromRecord which cannot fail and deprecate
the old one
- Some other minor clean-up & re-ordering
2024-06-27 15:15:23 +02:00
.github/workflows test Nim 2.0 in CI and use non-EOL macOS version (#677) 2024-02-14 05:07:55 +00:00
doc fix build for `dcli` and instructions for new path (#638) 2023-09-22 10:32:43 +00:00
eth Rework of ENR decoding code (#709) 2024-06-27 15:15:23 +02:00
tests Rework of ENR decoding code (#709) 2024-06-27 15:15:23 +02:00
tools Rework of ENR decoding code (#709) 2024-06-27 15:15:23 +02:00
.gitignore normalise nimble, ci (#567) 2024-01-23 16:48:29 +00:00
LICENSE-APACHEv2 Moved eth-common to eth 2019-02-05 12:10:36 +02:00
LICENSE-MIT Moved eth-common to eth 2019-02-05 12:10:36 +02:00
README.md move rocksdb to nimbus-eth1 (#460) 2022-04-04 13:46:57 +02:00
config.nims Refactor p2pProtocol internals (#657) 2024-01-22 16:47:46 +07:00
eth.nimble results: use standalone repo (#687) 2024-05-30 14:46:57 +02:00
nim.cfg move -d:nimRawSetjmp to nim.cfg (#513) 2022-06-21 16:25:42 +02:00

README.md

eth - Eth Common Library

License: Apache License: MIT Stability: experimental Github action

Introduction

Ethereum-related utilities written in Nim. Includes things like Bloom filters, private/public key utilities, RLP, devp2p, and more.

Docs

Prerequisites

  • Nim & Nimble

Building & Testing

# Install required modules
nimble install
# Run full test suite
nimble test

You can also run specific parts of the test suite, e.g.:

# Test p2p functionality
nimble test_p2p
# Test rlp functionality
nimble test_rlp

Fuzzing

Next to the test suite, there are also several fuzzing test cases available. How these can be run is explained in the fuzzing readme.

License

Licensed and distributed under either of

or

at your option. This file may not be copied, modified, or distributed except according to those terms.