This library is designed to integrate tantivy into DingoDB.
All FFI (Foreign Function Interface) functions are exposed in lib.rs. Developers need to regenerate the header file after making any changes to the relevant code:
cbindgen . -o include/tantivy_search_cbindgen.h --config cbindgen.toml
cxxbridge src/lib.rs --header > include/tantivy_search_cxx.hDevelopers can use gen-cxx-header.sh to do this too.
If developers do not add, delete, or modify the names of FFI functions, there is no need to execute the above command.
If developers do not have cbindgen or cxxbridge, install like this:
cargo install cbindgen
cargo install cxxbridge-cmd- Added unit tests in C++ to test Rust FFI functions.
- Add additional unit tests within Rust FFI functions.
- Refactor the
tantivy_searchcode using object-oriented principles.
You can use cargo to build this library, use this command:
cargo build --releaseIf you need to test FFI function in C++, run:
mkdir build
cd build && cmake ..
make -jYou can use vscode or other compilers to make the build process more elegant.
Test in Rust:
cargo testHere is an example to run unit test in C++:
cd build/tests/unit_test
./unit_testWe give special thanks for these open-source projects, upon which we have developed:
- Tantivy - A library for full-text search.
- tantivy-search - A library is designed to integrate tantivy into ClickHouse and MyScaleDB.
- cang-jie - A Chinese tokenizer for tantivy, based on jieba-rs.