7 releases (breaking)

new 0.7.0 Apr 16, 2024
0.6.0 Mar 27, 2023
0.5.0 Mar 27, 2023
0.4.0 Sep 2, 2020
0.1.0 Mar 10, 2019

#276 in #low-level


Used in sfcgal

MIT/Apache

10KB
188 lines

sfcgal-sys

Build Crates.io

Rust low-level FFI bindings to SFCGAL 1.5.x C API.
Don't use this crate directly, prefer it's higher-level wrapper : sfcgal-rs.

Internals

This crate contains a few lines of C code (compiled as a static library with cc crate) wrapping SFCGAL C API in order to replace the error and warning handlers (which use printf by default).
It expects SFCGAL to be installed as a system library and that you have the header file for it's C API. Then bindgen is run to generate these low-levels bindings.

In addition to all the sfcgal_ types and functions, this crate expose :

  • a Rust initialize function: it calls sfcgal_init() function then it calls a custom w_sfcgal_init_handlers() function which replace the error and warning handlers from printf to a char buffer. That initialize function internally uses std::sync::Once to ensure it's only called once.
  • two C functions w_sfcgal_get_last_error and w_sfcgal_get_last_warning which repectively reads the buffer containing the error message and the buffer containing the warning message.

In the future it could probably be improved by not requiring SFCGAL to be installed as a system library.

License

Licensed under either of

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you shall be dual licensed as above, without any additional terms or conditions.

No runtime deps

~0–2MB
~40K SLoC