Crates.io | rustsat-cadical |
lib.rs | rustsat-cadical |
version | 0.4.1 |
source | src |
created_at | 2023-08-23 13:18:46.160856 |
updated_at | 2024-10-16 14:42:23.101005 |
description | Interface to the SAT solver CaDiCaL for the RustSAT library. |
homepage | |
repository | https://github.com/chrjabs/rustsat |
max_upload_size | |
id | 952017 |
size | 6,939,878 |
Armin Biere's SAT solver CaDiCaL to be used with the RustSAT library.
Note: at the moment this crate is known to not work on Windows since CaDiCaL is non-trivial to get to work on Windows.
debug
: if this feature is enables, the C++ library will be built with debug and check functionality if the Rust project is built in debug modesafe
: disable writing through 'popen' for more safe usage of the library in applicationsquiet
: exclude message and profiling code (logging too)logging
: include logging code (but disabled by default)CaDiCaL versions can be selected via cargo crate features. All CaDiCaL versions up to Version 2.1.0 are available. For the full list of versions and the changelog see the CaDiCaL releases.
Without any features selected, the newest version will be used. If conflicting CaDiCaL versions are requested, the newest requested version will be selected.
In order to build a custom version of CaDiCaL, this crate supports two environment variables to customize the C++ source code that CaDiCaL is built from.
CADICAL_PATCHES
allows to specify a list of colon-separated paths to patch files that will
be applied to the CaDiCaL source repository before building it. These patches are applied
in order of appearance after the patches of this crate have been applied.CADICAL_SRC_DIR
allows for overriding where the C++ library is built from. By default this
crate fetches the appropriate code from the GitHub
repo. If this variable is set, the directory specified
there is used instead. Note that when using this variable, the crate will not apply any
patches, the user is responsible for applying the appropriate and necessary patches from the
patches/
directory.