creusot_contracts/std/default.rs
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54
use crate::*;
#[cfg(creusot)]
pub use creusot_contracts_proc::Default;
/// Extension of the standard [`Default`](::std::default::Default) trait.
///
/// This allows Creusot to specify the behavior of [`default`](::std::default::Default::default).
///
/// # Derive macro
///
/// Similarly to `std`, Creusot defines a derive macro for `Default`:
/// ```
/// use creusot_contracts::Default;
///
/// #[derive(Default)]
/// struct S(i32);
/// ```
///
/// This will implement both `Default` traits, and generate a proof obligation to show
/// that they agree.
pub trait Default: ::std::default::Default {
#[predicate(prophetic)]
fn is_default(self) -> bool;
}
extern_spec! {
mod std {
mod default {
trait Default where Self : Default {
#[ensures(result.is_default())]
fn default() -> Self;
}
}
}
}
impl Default for bool {
#[predicate]
#[open]
fn is_default(self) -> bool {
pearlite! { self == false }
}
}
// `RandomState::default()` is defined as `RandomState::new()`
// which produces random values.
impl Default for std::hash::RandomState {
#[predicate]
#[open]
fn is_default(self) -> bool {
pearlite! { true }
}
}