#coin-or #bonmin #bonmin-sys

sys coinbonmin-sys

The low-level bindings to the COIN-OR Clp library

1 unstable release

0.1.0 Jan 27, 2024

#2545 in Algorithms

Apache-2.0

8KB

Coinpopt-sys

Package Documentation License

coinbonmin-sys crate is a *-sys crate. The package provides Low-level bindings to the Bonmin library.

By this package, you don't need to worry about installing Bonmin in the system, and it's a package for all platforms.

Bonmin (Basic Open-source Nonlinear Mixed INteger programming) is an open-source code for solving general MINLP (Mixed Integer NonLinear Programming) problems.

Usage

Just add the following to your Cargo.toml:

[dependencies]
coinbonmin-sys = "0.1"

Configuration

The following Cargo features are supported:

  • default

The package build from the source and link statically by default. It also provide the following environment variables to allow users to link to system library customly:

  • CARGO_BOMIN_STATIC to link to Bonmin statically;
  • CARGO_BOMIN_SYSTEM to link to Bonmin system library;

Set the environment variable to 1 to enable the feature. For example, to link to system library dynamically, set CARGO_${LIB_NAME}_SYSTEM to 1; to link to system library statically, set both CARGO_${LIB_NAME}_SYSTEM and CARGO_${LIB_NAME}_STATIC to 1.

You can also use bonmin-sys with no-default-features, and add bonmin-src to the Cargo.toml and enable the related feature defined by bonmin-src. Please see Bonmin-src.

Windows and vcpkg

On Windows, if ${LIB_NAME}_SYSTEM is set to 1, bonmin-src will use [vcpkg] to find Bonmin. Before building, you must have the correct Bonmin installed for your target triplet and kind of linking. For instance, to link dynamically for the x86_64-pc-windows-msvc toolchain, install bonmin for the x64-windows triplet:

vcpkg install bonmin --triplet x64-windows

To link Bonmin statically, install bonmin for the x64-windows-static-md triplet:

vcpkg install bonmin --triplet x64-windows-static-md

To link Bonmin and C Runtime (CRT) statically, install bonmin for the x64-windows-static triplet:

vcpkg install bonmin --triplet x64-windows-static

and build with +crt-static option

RUSTFLAGS='-C target-feature=+crt-static' cargo build --target x86_64-pc-windows-msvc

Please see the "Static and dynamic C runtimes" in The Rust reference for detail.

Cross Compilation

Because [openblas-src]'s Issue #101, we can't cross compile the package with openblas-static feature. So, if you want to cross compile the package, you could use mike-kfed instead.

Add this to your project/.cargo/config.toml.

[patch.crates-io]
openblas-src = { git = "https://github.com/mike-kfed/openblas-src.git", branch = "arm-cross-compile" }

you can compile it for the other target by providing the --target option to cargo build.

Target supported
arm-unknown-linux-gnueabi
arm-unknown-linux-gnueabihf
armv7-linux-androideabi
armv7-unknown-linux-gnueabi
armv7-unknown-linux-gnueabihf
armv7-unknown-linux-musleabi
armv7-unknown-linux-musleabihf
riscv64gc-unknown-linux-gnu
x86_64-pc-windows-msvc
x86_64-unknown-linux-gnu

Contribution

Your contribution is highly appreciated. Do not hesitate to open an issue or a pull request. Note that any contribution submitted for inclusion in the project will be licensed according to the terms given in LICENSE.

Dependencies

~21MB
~518K SLoC