This crate provides a library with builder API for assembling C/C++ code from Rust.
Code contributions are welcome. The submitter must use the sign-off feature for all commits confirming that the submitter has all rights to contribute the code under the license without any additional terms or conditions.
See the AUTHORS file for a list of contributors.
This crate is inspired by codegen-rs`
To use crustal
clone the repository into the lib
folder of your Rust project,
or use crates.io
You can use crustal
by adding the following lines to Cargo.toml
file.
toml
[dependencies]
crustal
Next, create a Scope
and use the builder API to create elements in the scope.
Lastly, call Scope::to_string()
to get formatted C code as a string.
```rust use crustal as CG;
let mut scope = CG::Scope::new(); scope.setfilename("include/myfile.hpp");
scope.pushdocstr("WARNING: This is auto-generated comment\n"); scope.new_include("stdio.h", true);
scope.newclass("MyClass") .setbase("StateBase", CG::Visibility::Public) .pushattribute(Attribute::new("name", Type::newint(8)));
println!("{}", scope.to_string()); ```