1 unstable release

0.1.0-pre.1 Jun 18, 2024
0.1.0-alpha.1 Oct 7, 2024

#434 in Rust patterns

Download history 207/week @ 2024-07-21 54/week @ 2024-07-28 93/week @ 2024-08-04 61/week @ 2024-08-11 163/week @ 2024-08-18 74/week @ 2024-08-25 193/week @ 2024-09-01 302/week @ 2024-09-08 289/week @ 2024-09-15 257/week @ 2024-09-22 519/week @ 2024-09-29 525/week @ 2024-10-06 398/week @ 2024-10-13 453/week @ 2024-10-20 638/week @ 2024-10-27 693/week @ 2024-11-03

2,208 downloads per month
Used in 7 crates (3 directly)

Apache-2.0

19KB
326 lines

hax library

This crate contains helpers that can be used when writing Rust code that is proven through the hax toolchain.

⚠️ The code in this crate has no effect when compiled without the --cfg hax.

Examples:

fn sum(x: Vec<u32>, y: Vec<u32>) -> Vec<u32> {
  hax_lib::assume!(x.len() == y.len());
  hax_lib::assert!(hax_lib::forall(|i: usize| hax_lib::implies(i < x.len(), || x[i] < 4242)));
  hax_lib::debug_assert!(hax_lib::exists(|i: usize| hax_lib::implies(i < x.len(), || x[i] > 123)));
  x.into_iter().zip(y.into_iter()).map(|(x, y)| x + y).collect()
}

lib.rs:

Hax-specific helpers for Rust programs. Those helpers are usually no-ops when compiled normally but meaningful when compiled under hax.

Example:

fn sum(x: Vec<u32>, y: Vec<u32>) -> Vec<u32> {
  hax_lib::assume!(x.len() == y.len());
  hax_lib::assert!(hax_lib::forall(|i: usize| hax_lib::implies(i < x.len(), || x[i] < 4242)));
  hax_lib::debug_assert!(hax_lib::exists(|i: usize| hax_lib::implies(i < x.len(), || x[i] > 123)));
  x.into_iter().zip(y.into_iter()).map(|(x, y)| x + y).collect()
}

Dependencies

~400–770KB
~16K SLoC