Struct crypto::fortuna::Fortuna [-] [+] [src]

pub struct Fortuna {
    // some fields omitted
}

The Fortuna CSPRNG (PC 9.5)

Methods

impl Fortuna

fn new_unseeded() -> Fortuna

Creates a new unseeded Fortuna (PC 9.5.4)

fn add_random_event(&mut self, s: u8, i: usize, e: &[u8])

Adds a random event e from source s to entropy pool i (PC 9.5.6)

Trait Implementations

impl Rng for Fortuna

fn fill_bytes(&mut self, dest: &mut [u8])

Generate a bunch of random data into dest (PC 9.5.5)

Failure modes

If the RNG has not been seeded, and there is less than MIN_POOL_SIZE bytes of data in the first accumulator pool, this function will fail the task.

fn next_u32(&mut self) -> u32

fn next_u64(&mut self) -> u64

fn next_f32(&mut self) -> f32

fn next_f64(&mut self) -> f64

fn gen<T>(&mut self) -> T where T: Rand

fn gen_iter<T>(&'a mut self) -> Generator<'a, T, Self> where T: Rand

fn gen_range<T>(&mut self, low: T, high: T) -> T where T: SampleRange, T: PartialOrd<T>

fn gen_weighted_bool(&mut self, n: usize) -> bool

fn gen_ascii_chars(&'a mut self) -> AsciiGenerator<'a, Self>

fn choose<T>(&mut self, values: &'a [T]) -> Option<&'a T>

fn shuffle<T>(&mut self, values: &mut [T])

impl<'a> SeedableRng<&'a [u8]> for Fortuna

fn from_seed(seed: &'a [u8]) -> Fortuna

fn reseed(&mut self, seed: &'a [u8])