Docs | Crates.io |
---|---|
IPASIR is a simple C interface to incremental SAT solvers. (It stands for Reentrant Incremental Sat solver API, in reverse.) This interface is supported by a few different solvers because it is used in the SAT competition's incremental track. The IPASIR distribution, containing the interface and some sample solvers, can be found at this GitHub repository. This IPASIR library is an attempt to semi-soundly allow Rust programs to interface with such SAT solver libraries.
For users of this FFI there are two distinct ways of usage.
Users can build their application on top of the raw
module that offers direct but unsafe calls
into the C-API.
The recommended way to use this FFI is to use the Solver
type that acts as safe wrapper around
the C-API.
Allocate a new solver instance with: ipasir::Solver::init()
Licensed under either of
- Apache license, Version 2.0, (LICENSE-APACHE or http://www.apache.org/licenses/LICENSE-2.0)
- MIT license (LICENSE-MIT or http://opensource.org/licenses/MIT)
at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.
- Implement
Error
andDisplay
for the error types of the crate.
- Major API overhaul
ipasir::ffi::Solver
is now the FFI C targeting solver wrapper for Rust.IpasirSolver
is the trait to be implemented by Rust IPASIR compatible solvers
- Renamed
raw
module tosys
to better fit with the rest of the ecosystem. Lit::to_raw
is no longer publicly visible.- Removed
LitOrEnd
andEndOfClause
. - Split
Solver::add
API intoSolver::add_lit
andSolver::finalize_clause
. - Add
Clause::len
andClause::get
methods. - Add
Lit::new_unchecked
constructor. - Add
Lit::sign
andSign
enum. - Add
Lit::var
method. - Make
SolveControl
now publicly visible. (Was accidentally private before.)
- Initial Release