2018-05-27 12:13:55 -07:00
# Nimbus: an Ethereum 2.0 Sharding Client for Resource-Restricted Devices
2018-02-06 21:20:06 +02:00
2018-04-06 16:52:10 +02:00
[![Build Status (Travis) ](https://img.shields.io/travis/status-im/nimbus/master.svg?label=Linux%20/%20macOS "Linux/macOS build status (Travis )")](https://travis-ci.org/status-im/nimbus)
2018-09-04 21:03:10 -06:00
[![Windows build status (Appveyor) ](https://img.shields.io/appveyor/ci/nimbus/nimbus/master.svg?label=Windows "Windows build status (Appveyor )")](https://ci.appveyor.com/project/nimbus/nimbus)
[![License: Apache ](https://img.shields.io/badge/License-Apache%202.0-blue.svg )](https://opensource.org/licenses/Apache-2.0)
2018-04-06 16:52:10 +02:00
[![License: MIT ](https://img.shields.io/badge/License-MIT-blue.svg )](https://opensource.org/licenses/MIT)
![Stability: experimental ](https://img.shields.io/badge/stability-experimental-orange.svg )
2018-02-07 18:50:28 +02:00
2018-03-17 16:39:13 +08:00
Join the Status community chats:
2018-08-31 16:23:51 -06:00
[![Gitter: #status-im/nimbus ](https://img.shields.io/badge/gitter-status--im%2Fnimbus-orange.svg )](https://gitter.im/status-im/nimbus)
2018-03-17 16:39:13 +08:00
[![Riot: #nimbus ](https://img.shields.io/badge/riot-%23nimbus%3Astatus.im-orange.svg )](https://chat.status.im/#/room/#nimbus:status .im)
2018-09-04 21:01:33 -06:00
[![Riot: #dev-status ](https://img.shields.io/badge/riot-%23dev--status%3Astatus.im-orange.svg )](https://chat.status.im/#/room/#dev -status:status.im)
2018-03-17 16:39:13 +08:00
2018-05-16 21:51:17 -07:00
## Rationale
2018-11-22 14:00:24 +01:00
[Nimbus: an Ethereum 2.0 Sharding Client ](https://our.status.im/nimbus-for-newbies/ ). The code in this repository is currently focusing on Ethereum 1.0 feature parity, while all 2.0 research and development is happening in parallel in [nim-beacon-chain ](https://github.com/status-im/nim-beacon-chain ). The two repositories are expected to merge in Q1 2019.
2018-04-06 16:52:10 +02:00
2018-06-19 21:19:07 +02:00
## Building & Testing
2018-06-24 17:34:32 +03:00
### Prerequisites
2018-08-31 16:23:51 -06:00
* A recent version of Nim
* We use the version in the [Status fork ](https://github.com/status-im/Nim )
* Follow the Nim installation instructions or use [choosenim ](https://github.com/dom96/choosenim ) to manage your Nim versions
* A recent version of Facebook's [RocksDB ](https://github.com/facebook/rocksdb/ )
2018-09-24 12:21:21 -07:00
* Compile [from source ](https://github.com/facebook/rocksdb/blob/master/INSTALL.md ) or use the package manager of your OS; for example, [Debian ](https://packages.debian.org/search?keywords=librocksdb-dev&searchon=names&exact=1&suite=all§ion=all ), [Ubuntu ](https://packages.ubuntu.com/search?keywords=librocksdb-dev&searchon=names&exact=1&suite=all§ion=all ), and [Fedora ](https://apps.fedoraproject.org/packages/rocksdb ) have working RocksDB packages
2018-06-19 21:19:07 +02:00
2018-09-25 01:25:17 +03:00
#### Obtaining the prerequisites through the Nix package manager
2018-06-24 17:34:32 +03:00
Users of the [Nix package manager ](https://nixos.org/nix/download.html ) can install all prerequisites simply by running:
``` bash
nix-shell nimbus.nix
```
2018-09-25 02:10:38 +03:00
### Build & Install
2018-06-24 17:34:32 +03:00
2018-08-31 16:23:51 -06:00
We use [Nimble ](https://github.com/nim-lang/nimble ) to manage dependencies and run tests.
2018-06-19 21:19:07 +02:00
2018-09-25 01:25:17 +03:00
To build and install Nimbus in your home folder, just execute:
2018-08-31 16:23:51 -06:00
```bash
2018-09-25 01:25:17 +03:00
nimble install
2018-08-31 16:23:51 -06:00
```
2018-07-20 22:02:52 +02:00
2018-09-25 01:25:17 +03:00
After a succesful installation, running `nimbus --help` will provide you with a list of
the available command-line options. To start syncing with mainnet, just execute `nimbus`
without any parameters.
2018-07-20 22:02:52 +02:00
2018-09-25 01:25:17 +03:00
To execute all tests:
2018-08-31 16:23:51 -06:00
```bash
2018-09-25 01:25:17 +03:00
nimble test
2018-08-31 16:23:51 -06:00
```
2018-07-20 22:02:52 +02:00
2018-09-25 01:25:17 +03:00
Our Wiki provides additional helpful information for [debugging individual test cases][1]
and for [pairing Nimbus with a locally running copy of Geth][2].
[1]: https://github.com/status-im/nimbus/wiki/Understanding-and-debugging-Nimbus-EVM-JSON-tests
[2]: https://github.com/status-im/nimbus/wiki/Debugging-state-reconstruction
2018-07-20 22:02:52 +02:00
2018-08-31 16:23:51 -06:00
#### Troubleshooting
Sometimes, the build will fail even though the latest CI is green - here are a few tips to handle this:
* Wrong Nim version
* We depend on many bleeding-edge features - Nim regressions often happen
* Use the [Status fork ](https://github.com/status-im/Nim ) of Nim
* Wrong versions of dependencies
* nimble dependency tracking often breaks due to its global registry
* wipe the nimble folder and try again
* C compile or link fails
* Nim compile cache is pretty buggy and sometimes will fail to recompile
* wipe your nimcache folder
2018-07-20 22:02:52 +02:00
2018-04-06 16:52:10 +02:00
## License
2018-09-04 21:37:47 -06:00
Licensed under both of the following:
2018-04-06 16:52:10 +02:00
* Apache License, Version 2.0, ([LICENSE-APACHE ](LICENSE-APACHE ) or http://www.apache.org/licenses/LICENSE-2.0)
2018-05-16 22:03:36 -07:00
* MIT license: [LICENSE-MIT ](LICENSE-MIT ) or http://opensource.org/licenses/MIT