This crate provides a c foreign function internface (ffi) for delta-kernel-rs.
You can build static and shared-libraries, as well as the include headers by simply running:
cargo build [--release]
This will place libraries in the root target
dir (../target/[debug,release]
from the directory containing this README), and headers in ../target/ffi-headers
. In that directory there will be a delta_kernel_ffi.h
file, which is the C header, and a delta_kernel_ffi.hpp
which is the C++ header.
To build and run the excample C program which exercises FFI (after building the ffi as above):
cd examples/read-table
mkdir build
cd build
cmake ..
make
./read_table ../../../../kernel/tests/data/table-with-dv-small
Note there are two configurations that can currently be configured in cmake:
# turn on VERBOSE mode (default is off) - print more diagnostics
$ cmake -DVERBOSE=yes ..
# turn off PRINT_DATA (default is on) - see below
$ cmake -DPRINT_DATA=no ..
By default this has a dependency on
arrow-glib
. You can read install
instructions for your platform here.
If you don't want to install arrow-glib
you can run the above cmake
command as:
cmake -DPRINT_DATA=no ..
and the example will only print out the schema of the table, not the data.
By default the VSCode C/C++ Extension does not use any defines flags. You can open settings.json
and set the following line:
"C_Cpp.default.defines": [
"DEFINE_DEFAULT_ENGINE",
"DEFINE_SYNC_ENGINE"
]