From 2144870e5c5821edb688d2d00c86e4ac5f1b1e8c Mon Sep 17 00:00:00 2001 From: Yuya Nishihara Date: Sat, 14 Jan 2023 12:47:24 +0900 Subject: [PATCH] backend: reimplement random ChangeId generator without using UUID --- lib/src/settings.rs | 12 +++++------- 1 file changed, 5 insertions(+), 7 deletions(-) diff --git a/lib/src/settings.rs b/lib/src/settings.rs index b9399f3eb..f7ec56268 100644 --- a/lib/src/settings.rs +++ b/lib/src/settings.rs @@ -155,13 +155,11 @@ impl UserSettings { pub struct JJRng(Mutex); impl JJRng { pub fn new_change_id(&self) -> ChangeId { - let random_bytes = self.gen(); - // The `uuid` crate is used merely to specify the number of random bytes (16) - ChangeId::from_bytes( - uuid::Builder::from_random_bytes(random_bytes) - .into_uuid() - .as_bytes(), - ) + let mut random_bytes: [u8; 16] = self.gen(); + // TODO: make it fully random + random_bytes[6] = (random_bytes[6] & 0x0f) | ((4 as u8) << 4); // Version: 4 + random_bytes[8] = (random_bytes[8] & 0x3f) | 0x80; // Variant::RFC4122 + ChangeId::new(random_bytes.into()) } /// Wraps Rng::gen but only requires an immutable reference. Can be made