48 releases

0.25.8 Jan 6, 2025
0.25.7 May 15, 2024
0.25.6 Apr 22, 2024
0.25.5 Feb 22, 2024
0.2.0 Dec 20, 2019

#68 in #type-safe

Download history 293/week @ 2024-09-25 245/week @ 2024-10-02 293/week @ 2024-10-09 214/week @ 2024-10-16 216/week @ 2024-10-23 278/week @ 2024-10-30 179/week @ 2024-11-06 108/week @ 2024-11-13 148/week @ 2024-11-20 251/week @ 2024-11-27 194/week @ 2024-12-04 282/week @ 2024-12-11 209/week @ 2024-12-18 123/week @ 2024-12-25 627/week @ 2025-01-01 359/week @ 2025-01-08

1,351 downloads per month
Used in 10 crates (4 directly)

MIT/Apache

160KB
3.5K SLoC

ethcontract-generate

An alternative API for generating type-safe contract bindings from build.rs scripts. Using this method instead of the procedural macro has a couple advantages:

  • proper integration with with RLS and Racer for autocomplete support;
  • ability to inspect the generated code.

The downside of using the generator API is the requirement of having a build script instead of a macro invocation.

Getting Started

Using crate requires two dependencies - one for the runtime and one for the generator:

[dependencies]
ethcontract = { version = "...", default-features = false }

[build-dependencies]
ethcontract-generate = "..."

It is recommended that both versions be kept in sync or else unexpected behaviour may occur.

Then, in your build.rs include the following code:

use ethcontract_generate::loaders::TruffleLoader;
use ethcontract_generate::ContractBuilder;

fn main() {
    // Prepare filesystem paths.
    let out_dir = std::env::var("OUT_DIR").unwrap();
    let dest = std::path::Path::new(&out_dir).join("rust_coin.rs");
    
    // Load a contract.
    let contract = TruffleLoader::new()
        .load_contract_from_file("../build/Contract.json")
        .unwrap();
    
    // Generate bindings for it.
    ContractBuilder::new()
        .generate(&contract)
        .unwrap()
        .write_to_file(dest)
        .unwrap();
}

Relation to ethcontract-derive

ethcontract-derive uses ethcontract-generate under the hood so their generated bindings should be identical, they just provide different APIs to the same functionality.

The long term goal of this project is to maintain ethcontract-derive. For now there is no extra work in having it split into two separate crates. That being said if RLS support improves for procedural macro generated code, it is possible that this crate be deprecated in favour of ethcontract-derive as long as there is no good argument to keep it around.

Dependencies

~8–18MB
~246K SLoC