From 104fba45d09ad3dd1fa6beed12e690a811c2e6d3 Mon Sep 17 00:00:00 2001 From: Meadow Liu Date: Mon, 12 Aug 2024 23:14:45 -0700 Subject: [PATCH] some doc comments for rand --- src/rand/mod.rs | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/src/rand/mod.rs b/src/rand/mod.rs index d3efe3809..c7074d868 100644 --- a/src/rand/mod.rs +++ b/src/rand/mod.rs @@ -21,11 +21,14 @@ macro_rules! decl_thread_local_rng { } impl $struct_name { + /// Generates a random value of type `T` using this generator #[inline] pub fn gen_rand() -> T { RNG_STATIC.with_borrow_mut(|rng| T::gen_rand(rng)) } + /// Fills a slice of values of type `T` using this generator + #[inline] pub fn fill(slice: &mut [T]) { RNG_STATIC.with_borrow_mut(|rng| T::fill(rng, slice)) } @@ -76,9 +79,13 @@ decl_thread_local_rng! { impl CryptoRng for ThreadLocalChaCha20Rng {} +/// A trait for items that can be randomly generated from a given +/// random number generator pub trait Randomisable: Sized { + /// Generates a random value with the given random number generator fn gen_rand(rng: &mut R) -> Self; + /// Fills a slice with the given random number generator #[inline] fn fill(rng: &mut R, slice: &mut [Self]) { for slot in slice {