Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/dushistov/flapigen-rs
Tool for connecting programs or libraries written in Rust with other languages
https://github.com/dushistov/flapigen-rs
c codegen cpp java jni rust swig wrapper
Last synced: 2 days ago
JSON representation
Tool for connecting programs or libraries written in Rust with other languages
- Host: GitHub
- URL: https://github.com/dushistov/flapigen-rs
- Owner: Dushistov
- License: bsd-3-clause
- Created: 2016-10-26T09:32:33.000Z (about 8 years ago)
- Default Branch: master
- Last Pushed: 2024-11-11T16:05:40.000Z (2 months ago)
- Last Synced: 2025-01-01T23:06:11.344Z (9 days ago)
- Topics: c, codegen, cpp, java, jni, rust, swig, wrapper
- Language: Rust
- Homepage:
- Size: 10.2 MB
- Stars: 787
- Watchers: 17
- Forks: 59
- Open Issues: 64
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# flapigen [![Build Status](https://github.com/Dushistov/flapigen-rs/actions/workflows/ci.yml/badge.svg)](https://github.com/Dushistov/flapigen-rs/actions/workflows/ci.yml) [![License](https://img.shields.io/badge/license-BSD-green.svg)](https://github.com/Dushistov/flapigen-rs/blob/master/LICENSE) [![Rust Documentation](https://img.shields.io/badge/api-rustdoc-blue.svg)](https://docs.rs/flapigen)
Tool for connecting programs or libraries written in Rust with other languages.
Foreign language api generator - flapigen. Former name rust_swig was changed to not confuse
with [swig](https://github.com/swig/swig).
Currently implemented support for `C++` and `Java`, but you can write support
for any language of your choice. For an instruction how to integrate flapigen with your
project look [here](https://dushistov.github.io/flapigen-rs/getting-started.html).Suppose you have the following Rust code:
```rust
struct Foo {
data: i32
}impl Foo {
fn new(val: i32) -> Foo {
Foo{data: val}
}fn f(&self, a: i32, b: i32) -> i32 {
self.data + a + b
}fn set_field(&mut self, v: i32) {
self.data = v;
}
}fn f2(a: i32) -> i32 {
a * 2
}
```and you want to write in Java something like this:
```Java
Foo foo = new Foo(5);
int res = foo.f(1, 2);
assert res == 8;
```
or in C++ something like this:```C++
Foo foo(5);
int res = foo.f(1, 2);
assert(res == 8);
```In order to implement it flapigen suggests the following functionality,
in Rust project you write (in Rust language):```rust
foreign_class!(class Foo {
self_type Foo;
constructor Foo::new(_: i32) -> Foo;
fn Foo::set_field(&mut self, _: i32);
fn Foo::f(&self, _: i32, _: i32) -> i32;
fn f2(_: i32) -> i32;
});
```and that's all, as a result flapigen generates JNI wrappers for Rust functions
and Java code to call these JNI functions
or generates C compatible wrappers in case of C++ and
C++ code to call these C functions.If you want the interface file (the file containing `foreign_class!` and so on)
to be automatically generated for you, checkout [rifgen](https://crates.io/crates/rifgen).## Users Guide
[📚 Read the `flapigen` users guide here! 📚](https://dushistov.github.io/flapigen-rs/)