Dustin Brody 2136bc74fd
Sanitize memory addresses and lengths (#97)
* add a helper function to ensure for memory addressing and length purposes, especially as applied to array indexing and bounds-checking, that non-negative UInt256 numbers remain non-negative when lossily converted to int's
2018-08-06 16:33:20 +00:00
2018-07-17 19:18:59 +02:00
2018-07-28 12:42:40 +03:00
2018-05-30 19:11:15 +03:00
2018-07-20 22:02:52 +02:00

Nimbus: an Ethereum 2.0 Sharding Client for Resource-Restricted Devices

Build Status (Travis) Windows build status (Appveyor)License: Apache License: MIT Stability: experimental

Join the Status community chats: Riot: #dev-status Riot: #nimbus

Rationale

Nimbus: an Ethereum 2.0 Sharding Client

Building & Testing

Prerequisites

Please install a recent version of Facebook's RocksDB following the instructions here:

https://github.com/facebook/rocksdb/blob/master/INSTALL.md

Currently Nimbus requires the latest development version of the Nim programming language. Follow the installation steps or use choosenim.

Obtaining the prerequisites through the Nix package manager

Users of the Nix package manager can install all prerequisites simply by running:

nix-shell nimbus.nix

Build

You can build the package and run the tests using nimble test. You can run the example using nim compile --run examples/decompile_smart_contract.nim.

You can run the official Ethereum JSON tests for the EVM this way:

create a ./build directory with mkdir build in your cloned repository.

Run

nim c -r --nimcache:nimcache -o:build/test tests/test_vm_json.nim

The executable will be put in build, and nim compilation cache will use nimcache.

License

Licensed under one of the following:

Description
Nimbus: an Ethereum Execution Client for Resource-Restricted Devices
https://status-im.github.io/nimbus-eth1/
Readme
Languages
Nim 97.8%
Shell 0.7%
Makefile 0.5%
CodeQL 0.4%
Nix 0.2%
Other 0.3%