about summary refs log tree commit diff
path: root/library/alloctests/testing/rng.rs
diff options
context:
space:
mode:
Diffstat (limited to 'library/alloctests/testing/rng.rs')
-rw-r--r--library/alloctests/testing/rng.rs28
1 files changed, 28 insertions, 0 deletions
diff --git a/library/alloctests/testing/rng.rs b/library/alloctests/testing/rng.rs
new file mode 100644
index 00000000000..77d3348f38a
--- /dev/null
+++ b/library/alloctests/testing/rng.rs
@@ -0,0 +1,28 @@
+/// XorShiftRng
+pub(crate) struct DeterministicRng {
+    count: usize,
+    x: u32,
+    y: u32,
+    z: u32,
+    w: u32,
+}
+
+impl DeterministicRng {
+    pub(crate) fn new() -> Self {
+        DeterministicRng { count: 0, x: 0x193a6754, y: 0xa8a7d469, z: 0x97830e05, w: 0x113ba7bb }
+    }
+
+    /// Guarantees that each returned number is unique.
+    pub(crate) fn next(&mut self) -> u32 {
+        self.count += 1;
+        assert!(self.count <= 70029);
+        let x = self.x;
+        let t = x ^ (x << 11);
+        self.x = self.y;
+        self.y = self.z;
+        self.z = self.w;
+        let w_ = self.w;
+        self.w = w_ ^ (w_ >> 19) ^ (t ^ (t >> 8));
+        self.w
+    }
+}