Raw rust bindings to SCIP's C-API. The bindings are automatically generated using bindgen. Meant to provide full control over SCIP's API, for a more restricted memory-safe API see russcip.
This crate depends on SCIP at runtime, the crate provides optional features (bundled, from-source) to install SCIP.
If no feature is enabled, it will look for a scip installation in the current conda environment, if it is not found it will look for the SCIPOPTDIR
environment variable.
to install SCIP using conda run the following command
conda install --channel conda-forge scip
The crate provides the bundled
feature that tries to download a precompiled binary for your OS and architecture
run the following command to add the crate with the bundled
feature
cargo add scip-sys --features bundled
The crate provides the from-source
feature that tries to download the source code and compile it. This provides the most flexibility but the compilation process can be slow.
run the following command to add the crate with the from-source
feature
cargo add scip-sys --features from-source
scip-sys
will emit the path where it found libscip in the environment variable DEP_SCIP_LIBDIR
at build time.
You can use this variable to find the path to the shared library at runtime. You can do so by adding the following to your build.rs
fn main() {
let libscip_dir = std::env::var("DEP_SCIP_LIBDIR").unwrap();
println!("cargo:rustc-link-arg=-Wl,-rpath,{}", libscip_dir);
}
This repo is distributed under the open-source Apache 2.0 license. Although, to simplify the building process the C-headers for the SCIPOptSuite and its dependent software are included. These dependencies include Bliss that is distributed under the GNU Lesser General Public license.