From 43f6f47f0a5711c514314234c26e8f83fcedcd1d Mon Sep 17 00:00:00 2001 From: kgmyatthu <2962000kaungmyatthu@gmail.com> Date: Wed, 1 May 2024 17:05:56 +0700 Subject: [PATCH] fix: better singleton pattern for SHARDUS_CRYPTO_INSTANCE This commit discharge the use of static mut to be able to compile with rust 1.77 --- shardus_net/src/shardus_crypto.rs | 32 +++++++++++-------------------- 1 file changed, 11 insertions(+), 21 deletions(-) diff --git a/shardus_net/src/shardus_crypto.rs b/shardus_net/src/shardus_crypto.rs index c191fa5..2fcfa57 100644 --- a/shardus_net/src/shardus_crypto.rs +++ b/shardus_net/src/shardus_crypto.rs @@ -1,32 +1,22 @@ -use crypto::ShardusCrypto; use std::sync::Once; +use crypto::ShardusCrypto; +use once_cell::sync::OnceCell; +static SHARDUS_CRYPTO_INSTANCE: OnceCell = OnceCell::new(); static INIT: Once = Once::new(); -// TODO figure out optimal way to lock mutability of this static as soon as it's initialized once. -// - Mutex locks both read write access, will lock out all threads that want to read? #BAD -// - Can we use RwLock? -static mut SHARDUS_CRYPTO_INSTANCE: Option = None; - +// Initialize the ShardusCrypto instance exactly once pub fn initialize_shardus_crypto_instance(hex_key: &str) { - INIT.call_once(|| match unsafe { &SHARDUS_CRYPTO_INSTANCE } { - Some(_) => { - panic!("ShardusCrypto instance already initialized"); - } - None => { - let crypto = ShardusCrypto::new(hex_key); - unsafe { - SHARDUS_CRYPTO_INSTANCE = Some(crypto); - } + INIT.call_once(|| { + let crypto = ShardusCrypto::new(hex_key); + // Attempt to set the OnceCell, which should never fail since it's guarded by `INIT.call_once()` + if SHARDUS_CRYPTO_INSTANCE.set(crypto).is_err() { + panic!("ShardusCrypto instance has already been initialized, this should never happen"); } }); } +// Get a reference to the initialized ShardusCrypto instance pub fn get_shardus_crypto_instance() -> &'static ShardusCrypto { - unsafe { - match &SHARDUS_CRYPTO_INSTANCE { - Some(instance) => instance, - None => panic!("ShardusCrypto instance not initialized"), - } - } + SHARDUS_CRYPTO_INSTANCE.get().expect("ShardusCrypto instance not initialized") }