#random #rand #random-rs

no-std random-trait

Rust library for a random trait meant to produce random generic types

2 releases

Uses old Rust 2015

0.1.1 Aug 26, 2019
0.1.0 Aug 26, 2019

#2730 in Algorithms

Download history 78/week @ 2024-11-16 88/week @ 2024-11-23 77/week @ 2024-11-30 128/week @ 2024-12-07 107/week @ 2024-12-14 90/week @ 2024-12-21 37/week @ 2024-12-28 74/week @ 2025-01-04 133/week @ 2025-01-11 97/week @ 2025-01-18 85/week @ 2025-01-25 174/week @ 2025-02-01 133/week @ 2025-02-08 83/week @ 2025-02-15 123/week @ 2025-02-22 75/week @ 2025-03-01

431 downloads per month
Used in 9 crates (via random-fast-rng)

MIT/Apache

15KB
265 lines

random-trait

Latest version Documentation License

A Rust library random-trait that helps generating random values in an easy and convinient way while still being a very thin library without dependencies.

This crate is inspired by the rand crate, but with the purpose of providing a very thin library, and support old compilers.

Usage

Add this to your Cargo.toml:

[dependencies]
random-trait = "0.1"

and for Rust Edition 2015 add this to your crate root:

extern crate random_trait;
use random_trait::{GenerateRand, Random};

In Rust Edition 2018 you can simply do:

use random_trait::{GenerateRand, Random};

After that you'll need to implement Random for your source of randomness,
And optionally also add GenerateRand implementations for your custom types.

Examples

use random_trait::{Random, GenerateRand};
 #[derive(Default)]
 struct MyRandomGenerator {
     ctr: usize,
 }

 impl Random for MyRandomGenerator {
     type Error = ();
     fn try_fill_bytes(&mut self, buf: &mut [u8]) -> Result<(), Self::Error> {
         for e in buf.iter_mut() {
             *e = self.ctr as u8;
             self.ctr += 1;
         }
         Ok(())
     }
 }

struct MyStuff {
    a: u64,
    b: char,
}

impl GenerateRand for MyStuff {
    fn generate<R: Random + ?Sized>(rand: &mut R) -> Self {
        MyStuff {a: rand.gen(), b: rand.gen() }
    }
}

fn get_random_stuff() -> MyStuff {
    let mut rand = MyRandomGenerator::default();
    rand.gen()
}

fn get_random_u128() -> u128 {
    let mut rand = MyRandomGenerator::default();
    rand.gen()
}

Dependencies