| Crates.io | z3-sys |
| lib.rs | z3-sys |
| version | 0.9.10 |
| created_at | 2015-12-28 02:31:50.656958+00 |
| updated_at | 2025-09-08 13:09:41.620063+00 |
| description | Low-level bindings for the Z3 SMT solver from Microsoft Research |
| homepage | https://github.com/prove-rs/z3.rs |
| repository | https://github.com/prove-rs/z3.rs.git |
| max_upload_size | |
| id | 3772 |
| size | 370,951 |
Low-level rust bindings to the Z3 SMT solver
Licensed under the MIT license.
See https://github.com/Z3Prover/z3 for details on Z3.
The API is fully documented with examples: https://docs.rs/z3-sys/
This crate works with Cargo and is on
crates.io.
Add it to your project with cargo add:
$ cargo add z3-sys
Note: This library has a dependency on Z3.
There are 4 ways for this crate to currently find Z3:
brew install z3). Users can use
the environment variable Z3_LIBRARY_PATH_OVERRIDE to manually
specify the library search path.bundled feature will use cmake to build and statically
link Z3. This feature, as is, is only usable when z3 or z3-sys is used
as a git dependency, as it assumes the existence of a git submodule for
Z3. Users wishing to use this feature with the release of z3 or z3-sys on
crates.io must set Z3_SYS_BUNDLED_DIR_OVERRIDE to point to
their own checkout of Z3.vcpkg feature will use vcpkg to build and
install a copy of Z3 which is then used.gh-release feature will download a pre-compiled
copy of Z3 from the GitHub release page for the current platform,
if available.
Z3_SYS_Z3_VERSION environment variable.gh-release feature
inside a CI pipeline (or if you cargo clean and rebuild a lot),
you will likely experience random 403 responses downloading the
z3 build artifacts. To mitigate this, generate a read-only Personal
Access Token (https://github.com/settings/personal-access-tokens) and
provide it to the READ_ONLY_GITHUB_TOKEN environment variable. The
build.rs step will automatically use this token (if present) to prevent
throttling.Note: This crate requires a z3.h during build time.
z3.h in standard/system
include paths. The Z3_SYS_Z3_HEADER environment variable can
also be used to customize this.bundled feature will cause the bundled copy of z3.h
to be used. The Z3_SYS_Z3_HEADER environment variable can also
be used to customize this.vcpkg or gh-release feature will cause the copy of
z3.h provided by that version to be used. In this case, there is
no override via the environment variable.I am developing this library largely on my own so far. I am able to offer support and maintenance, but would very much appreciate donations via Patreon. I can also provide commercial support, so feel free to contact me.
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.