Skip to content

SFCGAL low-level FFI bindings for Rust

License

Apache-2.0, MIT licenses found

Licenses found

Apache-2.0
LICENSE-APACHE
MIT
LICENSE-MIT
Notifications You must be signed in to change notification settings

mthh/sfcgal-sys

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

43 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

sfcgal-sys

Build Crates.io Documentation

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.

Important

Note that the required version of SFCGAL is currently 1.5.x (latest version - 2023-10-30).
If you want to use SFCCAL 1.4.x, you can use the 0.6.x version of this crate / of 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.