diff options
| author | Daniel Mueller <deso@posteo.net> | 2020-01-02 08:32:06 -0800 | 
|---|---|---|
| committer | Daniel Mueller <deso@posteo.net> | 2020-01-02 08:32:06 -0800 | 
| commit | fd091b04316db9dc5fafadbd6bdbe60b127408a9 (patch) | |
| tree | f202270f7ae5cedc513be03833a26148d9b5e219 /rand/rand_xorshift/src | |
| parent | 8161cdb26f98e65b39c603ddf7a614cc87c77a1c (diff) | |
| download | nitrocli-fd091b04316db9dc5fafadbd6bdbe60b127408a9.tar.gz nitrocli-fd091b04316db9dc5fafadbd6bdbe60b127408a9.tar.bz2 | |
Update nitrokey crate to 0.4.0
This change finally updates the version of the nitrokey crate that we
consume to 0.4.0. Along with that we update rand_core, one of its
dependencies, to 0.5.1. Further more we add cfg-if in version 0.1.10 and
getrandom in version 0.1.13, both of which are now new (non-development)
dependencies.
Import subrepo nitrokey/:nitrokey at e81057037e9b4f370b64c0a030a725bc6bdfb870
Import subrepo cfg-if/:cfg-if at 4484a6faf816ff8058088ad857b0c6bb2f4b02b2
Import subrepo getrandom/:getrandom at d661aa7e1b8cc80b47dabe3d2135b3b47d2858af
Import subrepo rand/:rand at d877ed528248b52d947e0484364a4e1ae59ca502
Diffstat (limited to 'rand/rand_xorshift/src')
| -rw-r--r-- | rand/rand_xorshift/src/lib.rs | 30 | 
1 files changed, 12 insertions, 18 deletions
| diff --git a/rand/rand_xorshift/src/lib.rs b/rand/rand_xorshift/src/lib.rs index db42ba2..b9fef23 100644 --- a/rand/rand_xorshift/src/lib.rs +++ b/rand/rand_xorshift/src/lib.rs @@ -17,14 +17,10 @@  #![no_std] -pub extern crate rand_core; - -#[cfg(feature="serde1")] extern crate serde; -#[cfg(feature="serde1")] #[macro_use] extern crate serde_derive; -  use core::num::Wrapping as w; -use core::{fmt, slice}; +use core::fmt;  use rand_core::{RngCore, SeedableRng, Error, impls, le}; +#[cfg(feature="serde1")] use serde::{Serialize, Deserialize};  /// An Xorshift random number generator.  /// @@ -75,7 +71,8 @@ impl RngCore for XorShiftRng {      }      fn try_fill_bytes(&mut self, dest: &mut [u8]) -> Result<(), Error> { -        Ok(self.fill_bytes(dest)) +        self.fill_bytes(dest); +        Ok(())      }  } @@ -102,22 +99,19 @@ impl SeedableRng for XorShiftRng {      }      fn from_rng<R: RngCore>(mut rng: R) -> Result<Self, Error> { -        let mut seed_u32 = [0u32; 4]; +        let mut b = [0u8; 16];          loop { -            unsafe { -                let ptr = seed_u32.as_mut_ptr() as *mut u8; - -                let slice = slice::from_raw_parts_mut(ptr, 4 * 4); -                rng.try_fill_bytes(slice)?; +            rng.try_fill_bytes(&mut b[..])?; +            if !b.iter().all(|&x| x == 0) { +                break;              } -            if !seed_u32.iter().all(|&x| x == 0) { break; }          }          Ok(XorShiftRng { -            x: w(seed_u32[0]), -            y: w(seed_u32[1]), -            z: w(seed_u32[2]), -            w: w(seed_u32[3]), +            x: w(u32::from_le_bytes([b[0], b[1], b[2], b[3]])), +            y: w(u32::from_le_bytes([b[4], b[5], b[6], b[7]])), +            z: w(u32::from_le_bytes([b[8], b[9], b[10], b[11]])), +            w: w(u32::from_le_bytes([b[12], b[13], b[14], b[15]])),          })      }  } | 
