#foreign-interface #java #jni #swig #cpp

flapigen

Tool for connecting libraries written in Rust with other languages

16 releases

0.8.0 Nov 11, 2024
0.7.0 Jun 5, 2024
0.6.1 Apr 9, 2024
0.6.0 Apr 16, 2023
0.6.0-pre13 Jul 14, 2022

#45 in FFI

Download history 219/week @ 2024-09-16 443/week @ 2024-09-23 593/week @ 2024-09-30 387/week @ 2024-10-07 440/week @ 2024-10-14 314/week @ 2024-10-21 359/week @ 2024-10-28 386/week @ 2024-11-04 376/week @ 2024-11-11 341/week @ 2024-11-18 202/week @ 2024-11-25 507/week @ 2024-12-02 466/week @ 2024-12-09 225/week @ 2024-12-16 74/week @ 2024-12-23 11/week @ 2024-12-30

810 downloads per month

BSD-3-Clause

800KB
22K SLoC

flapigen Build Status License Rust Documentation

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. 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.

Suppose you have the following Rust code:

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:

Foo foo = new Foo(5);
int res = foo.f(1, 2);
assert res == 8;

or in C++ something like this:

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):

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.

Users Guide

📚 Read the flapigen users guide here! 📚

Dependencies

~4–12MB
~160K SLoC