diff --git a/fish-rust/Cargo.lock b/fish-rust/Cargo.lock index 8fa57912a..ccd735abc 100644 --- a/fish-rust/Cargo.lock +++ b/fish-rust/Cargo.lock @@ -358,6 +358,7 @@ dependencies = [ "miette", "nix", "num-traits", + "once_cell", "unixstring", "widestring", "widestring-suffix", diff --git a/fish-rust/Cargo.toml b/fish-rust/Cargo.toml index d671ff5da..aa74d6b3a 100644 --- a/fish-rust/Cargo.toml +++ b/fish-rust/Cargo.toml @@ -15,6 +15,7 @@ lazy_static = "1.4.0" libc = "0.2.137" nix = { version = "0.25.0", default-features = false, features = [] } num-traits = "0.2.15" +once_cell = "1.17.0" unixstring = "0.2.7" widestring = "1.0.2" diff --git a/fish-rust/src/lib.rs b/fish-rust/src/lib.rs index e3645a42a..59005e146 100644 --- a/fish-rust/src/lib.rs +++ b/fish-rust/src/lib.rs @@ -4,9 +4,6 @@ #![allow(clippy::needless_return)] #![allow(clippy::manual_is_ascii_check)] -#[macro_use] -extern crate lazy_static; - mod fd_readable_set; mod fds; #[allow(rustdoc::broken_intra_doc_links)] diff --git a/fish-rust/src/wchar_ffi.rs b/fish-rust/src/wchar_ffi.rs index 32b75df67..0af4c27ad 100644 --- a/fish-rust/src/wchar_ffi.rs +++ b/fish-rust/src/wchar_ffi.rs @@ -9,6 +9,7 @@ use crate::ffi; pub use cxx::CxxWString; pub use ffi::{wchar_t, wcharz_t}; +use once_cell::sync::Lazy; pub use widestring::U32CString as W0String; pub use widestring::{u32cstr, utf32str}; pub use widestring::{Utf32Str as wstr, Utf32String as WString}; @@ -72,14 +73,12 @@ macro_rules! wcharz { pub(crate) use c_str; pub(crate) use wcharz; -lazy_static! { - /// A shared, empty CxxWString. - static ref EMPTY_WSTRING: cxx::UniquePtr = cxx::CxxWString::create(&[]); -} +static EMPTY_WSTRING: Lazy> = + Lazy::new(|| cxx::CxxWString::create(&[])); /// \return a reference to a shared empty wstring. pub fn empty_wstring() -> &'static cxx::CxxWString { - &EMPTY_WSTRING + &*EMPTY_WSTRING } /// Implement Debug for wcharz_t.