Cainome is a library to generate bindings from Cairo ABI.
Cainome architecture provides a flexible way to work with Cairo ABI for different languages (backends).
- cli: inside
src/bin/cli
, the cainome CLI binary can be built usingcargo build
: README. - lib: inside
src/lib.rs
, the cainome library can be built usingcargo build --lib
. - parser: a run-time library to parse an ABI file into
Token
s README. - cairo-serde: a compile-time library that implements serialization for native Rust types from
FieldElement
buffer README. - rs-macro: a compile-time library backend for the
abigen
macro to generate rust bindings README. - rs: a a run-time library to generated rust bindings README.
- ts: a compile-time library backend to generate
TypeScript
bindings (coming soon).
Currently those crates are not published on crates.io, please consider using them with the release tags.
Cainome uses a plugin system that is for now only supporting built-in
plugins (written in rust).
Cainome will support in the future plugins like protobuf
, which can be written in any languages.
Currently, to write a plugin you can take as example the RustPlugin
.
- Define a rust module inside
src/bin/cli/plugins/builtins
. - You can write your plugin code in a crate (like
rs
crate), or in the module you've created at the previous step (use a folder in this case). Writting a crate can be easier to re-use in other projects though. - The plugin takes a
PluginInput
as argument, where the tokens from the parser crate are available for each contract. From these tokens, you can easily generate code that represent the ABI of the contract. In the case of rust, you can find in thers
crate some examples of how types are handled. You don't have to usesyn
crate asrs
crate is doing. You can simply build strings. - In the current version, the plugin also receives the
output_dir
, so it is responsible of writing and organizing it's files. - Finally, add in the PluginOptions an option for your plugin.
Cainome is a word combining Cairo
and Genome
. The idea of Cairo ABI
being the DNA of our ecosystem,
and like the genome expresses several genes which turn into proteins, from an ABI
we can generate several bindings in different languages.