diff --git a/README.md b/README.md index 9ed5acecc..0d8a32040 100644 --- a/README.md +++ b/README.md @@ -103,28 +103,41 @@ A few basic steps are needed to get set up: 1. Install [rustup](https://rustup.rs/). It's a toolchain manager for Rust (Linux | macos | Windows). For installation run the below command in your terminal ``` $ curl https://sh.rustup.rs -sSf | sh -``` - 2. To configure your current shell run: + ``` + 2. (Linux & MacOS) To configure your current shell run: ``` $ source $HOME/.cargo/env -``` - - 3. Use the command `rustup show` to get information about the Rust installation. You should see that the active toolchain is the stable version. - 4. Run `rustc --version` to check the installation and version of rust. + ``` + 3. Use the command `rustup show` to get information about the Rust installation. You should see that the + active toolchain is the stable version. + 4. Run `rustc --version` to check the installation and version of rust. - Updates can be performed using` rustup update` . - 5. Install build dependancies (Arch packages are listed here, your distribution will - likely be similar): + 5. Install build dependencies (Arch packages are listed here, your distribution will likely be similar): - `clang`: required by RocksDB. - `protobuf`: required for protobuf serialization (gRPC). - 5. Navigate to the working directory. - 6. Run the test by using command `cargo test --all` . By running, it will pass all the required test cases. If you are doing it for the first time, then you can grab a coffee meantime. Usually, it takes time to build, compile and pass all test cases. If there is no error then, it means everything is working properly and it's time to get hand's dirty. In case, if there is an error, then please raise the [issue](https://github.com/sigp/lighthouse/issues). We will help you. - 7. As an alternative to, or instead of the above step, you may also run benchmarks by using the command `cargo bench --all` + 6. Navigate to the working directory. + 7. Run the test by using command `cargo test --all`. By running, it will pass all the required test cases. + If you are doing it for the first time, then you can grab a coffee in the meantime. Usually, it takes time + to build, compile and pass all test cases. If there is no error then it means everything is working properly + and it's time to get your hands dirty. + In case, if there is an error, then please raise the [issue](https://github.com/sigp/lighthouse/issues). + We will help you. + 8. As an alternative to, or instead of the above step, you may also run benchmarks by using + the command `cargo bench --all` ##### Note: Lighthouse presently runs on Rust `stable`, however, benchmarks currently require the `nightly` version. +##### Note for Windows users: +Perl may also be required to build lighthouse. You can install [Strawberry Perl](http://strawberryperl.com/), +or alternatively use a choco install command `choco install strawberryperl`. + +Additionally, the dependency `protoc-grpcio v0.3.1` is reported to have issues compiling in Windows. You can specify +a known working version by editing version in protos/Cargo.toml's "build-dependencies" section to +`protoc-grpcio = "<=0.3.0"`. + ### Contributing **Lighthouse welcomes contributors with open-arms.** diff --git a/eth2/utils/bls/Cargo.toml b/eth2/utils/bls/Cargo.toml index 3b26ee26e..465510c59 100644 --- a/eth2/utils/bls/Cargo.toml +++ b/eth2/utils/bls/Cargo.toml @@ -5,7 +5,7 @@ authors = ["Paul Hauner "] edition = "2018" [dependencies] -bls-aggregates = { git = "https://github.com/sigp/signature-schemes" } +bls-aggregates = { git = "https://github.com/sigp/signature-schemes", tag = "v0.3.0" } hashing = { path = "../hashing" } hex = "0.3" serde = "1.0" diff --git a/eth2/utils/ssz/src/tree_hash.rs b/eth2/utils/ssz/src/tree_hash.rs index fe5b1dfc3..a9ab0f467 100644 --- a/eth2/utils/ssz/src/tree_hash.rs +++ b/eth2/utils/ssz/src/tree_hash.rs @@ -30,8 +30,9 @@ pub fn merkle_hash(list: &mut Vec>) -> Vec { // Hash two chuncks together new_chunkz.append(&mut hash(two_chunks)); } - chunk_size = HASHSIZE; } + + chunk_size = HASHSIZE; chunkz = new_chunkz; } diff --git a/protos/build.rs b/protos/build.rs index d8becfa51..108d9e2dd 100644 --- a/protos/build.rs +++ b/protos/build.rs @@ -1,8 +1,10 @@ extern crate protoc_grpcio; +use std::path::Path; + fn main() { - let proto_root = "src/"; - println!("cargo:rerun-if-changed={}", proto_root); + let proto_root = Path::new("src"); + println!("cargo:rerun-if-changed={}", proto_root.display()); protoc_grpcio::compile_grpc_protos(&["services.proto"], &[proto_root], &proto_root) .expect("Failed to compile gRPC definitions!"); }