diff --git a/src/lib.rs b/src/lib.rs index 082dd37..7d92f1d 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -253,14 +253,12 @@ pub fn default_credential_builder() -> Box { } fn build_default_credential(target: Option<&str>, service: &str, user: &str) -> Result { - static DEFAULT: std::sync::OnceLock> = std::sync::OnceLock::new(); + static DEFAULT: std::sync::LazyLock> = + std::sync::LazyLock::new(default_credential_builder); let guard = DEFAULT_BUILDER .read() .expect("Poisoned RwLock in keyring-rs: please report a bug!"); - let builder = guard - .inner - .as_ref() - .unwrap_or_else(|| DEFAULT.get_or_init(|| default_credential_builder())); + let builder = guard.inner.as_ref().unwrap_or_else(|| &DEFAULT); let credential = builder.build(target, service, user)?; Ok(Entry { inner: credential }) }