/verify-rust-std

Verifying the Rust standard library

Primary LanguageRustOtherNOASSERTION

Rust std-lib verification

Rust Tests Build Book

This repository is a fork of the official Rust programming language repository, created solely to verify the Rust standard library. It should not be used as an alternative to the official Rust releases. The repository is tool agnostic and welcomes the addition of new tools.

The goal is to have a verified Rust standard library and prove that it is safe.

  1. Contributing to the core mechanism of verifying the rust standard library
  2. Creating new techniques to perform scalable verification
  3. Apply techniques to verify previously unverified parts of the standard library.

The Kani Rust Verifier is a bit-precise model checker for Rust. Kani verifies:

  • Memory safety (e.g., null pointer dereferences)
  • User-specified assertions (i.e assert!(...))
  • The absence of panics (eg., unwrap() on None values)
  • The absence of some types of unexpected behavior (e.g., arithmetic overflows).

You can find out more about Kani from the Kani book or the Kani repository on Github.

Contact

For questions, suggestions or feedback, feel free to open an issue here.

Security

See SECURITY for more information.

License

Kani

Kani is distributed under the terms of both the MIT license and the Apache License (Version 2.0). See LICENSE-APACHE and LICENSE-MIT for details.

Rust

Rust is primarily distributed under the terms of both the MIT license and the Apache License (Version 2.0), with portions covered by various BSD-like licenses.

See the Rust repository for details.

Introducing a New Tool

Please use the template available in this repository to introduce a new verification tool.