2024-01-22 05:34:15 +00:00
|
|
|
#[macro_export]
|
|
|
|
macro_rules! if_native {
|
|
|
|
($($item:item)*) => {$(
|
|
|
|
#[cfg(not(target_arch = "wasm32"))]
|
|
|
|
$item
|
|
|
|
)*}
|
|
|
|
}
|
|
|
|
|
|
|
|
#[macro_export]
|
|
|
|
macro_rules! if_wasm {
|
|
|
|
($($item:item)*) => {$(
|
|
|
|
#[cfg(target_arch = "wasm32")]
|
|
|
|
$item
|
|
|
|
)*}
|
|
|
|
}
|
2024-02-03 21:50:23 +00:00
|
|
|
// Define a generic macro to conditionally apply Send and Sync traits with documentation
|
|
|
|
#[macro_export]
|
|
|
|
macro_rules! conditional_send_sync_trait {
|
|
|
|
($doc:expr; $trait_name:ident { $( $item:tt )* }) => {
|
|
|
|
// For wasm32 targets, define the trait without Send + Sync
|
|
|
|
#[doc = $doc]
|
|
|
|
#[cfg(target_arch = "wasm32")]
|
|
|
|
pub trait $trait_name { $( $item )* }
|
|
|
|
|
|
|
|
// For non-wasm32 targets, define the trait with Send + Sync
|
|
|
|
#[doc = $doc]
|
|
|
|
#[cfg(not(target_arch = "wasm32"))]
|
|
|
|
pub trait $trait_name: Send + Sync { $( $item )* }
|
|
|
|
};
|
|
|
|
}
|
2024-01-22 05:34:15 +00:00
|
|
|
|
2023-02-13 01:29:49 +00:00
|
|
|
pub fn move_vec_element<T, F>(
|
|
|
|
vec: &mut Vec<T>,
|
|
|
|
filter: F,
|
|
|
|
_from_index: usize,
|
|
|
|
to_index: usize,
|
|
|
|
) -> Result<bool, String>
|
2022-04-28 08:02:03 +00:00
|
|
|
where
|
2023-02-13 01:29:49 +00:00
|
|
|
F: FnMut(&T) -> bool,
|
2022-04-28 08:02:03 +00:00
|
|
|
{
|
2023-02-13 01:29:49 +00:00
|
|
|
match vec.iter().position(filter) {
|
|
|
|
None => Ok(false),
|
|
|
|
Some(index) => {
|
|
|
|
if vec.len() > to_index {
|
|
|
|
let removed_element = vec.remove(index);
|
|
|
|
vec.insert(to_index, removed_element);
|
|
|
|
Ok(true)
|
|
|
|
} else {
|
|
|
|
let msg = format!(
|
|
|
|
"Move element to invalid index: {}, current len: {}",
|
|
|
|
to_index,
|
|
|
|
vec.len()
|
|
|
|
);
|
|
|
|
Err(msg)
|
|
|
|
}
|
|
|
|
},
|
|
|
|
}
|
2022-04-28 08:02:03 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#[allow(dead_code)]
|
|
|
|
pub fn timestamp() -> i64 {
|
2023-02-13 01:29:49 +00:00
|
|
|
chrono::Utc::now().timestamp()
|
2022-04-28 08:02:03 +00:00
|
|
|
}
|
2023-01-30 03:11:19 +00:00
|
|
|
|
|
|
|
#[inline]
|
|
|
|
pub fn md5<T: AsRef<[u8]>>(data: T) -> String {
|
2023-02-13 01:29:49 +00:00
|
|
|
let md5 = format!("{:x}", md5::compute(data));
|
|
|
|
md5
|
2023-01-30 03:11:19 +00:00
|
|
|
}
|
2024-04-07 13:36:55 +00:00
|
|
|
#[derive(Debug, Clone, PartialEq, Eq)]
|
2024-06-30 09:38:39 +00:00
|
|
|
pub enum OperatingSystem {
|
2024-04-07 13:36:55 +00:00
|
|
|
Unknown,
|
|
|
|
Windows,
|
|
|
|
Linux,
|
|
|
|
MacOS,
|
|
|
|
IOS,
|
|
|
|
Android,
|
|
|
|
}
|
|
|
|
|
2024-06-30 09:38:39 +00:00
|
|
|
impl OperatingSystem {
|
2024-04-07 13:36:55 +00:00
|
|
|
pub fn is_not_ios(&self) -> bool {
|
2024-06-30 09:38:39 +00:00
|
|
|
!matches!(self, OperatingSystem::IOS)
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn is_desktop(&self) -> bool {
|
|
|
|
matches!(
|
|
|
|
self,
|
|
|
|
OperatingSystem::Windows | OperatingSystem::Linux | OperatingSystem::MacOS
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn is_not_desktop(&self) -> bool {
|
|
|
|
!self.is_desktop()
|
2024-04-07 13:36:55 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-06-30 09:38:39 +00:00
|
|
|
impl From<String> for OperatingSystem {
|
2024-04-07 13:36:55 +00:00
|
|
|
fn from(s: String) -> Self {
|
2024-06-30 09:38:39 +00:00
|
|
|
OperatingSystem::from(s.as_str())
|
2024-04-07 13:36:55 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-06-30 09:38:39 +00:00
|
|
|
impl From<&String> for OperatingSystem {
|
2024-04-07 13:36:55 +00:00
|
|
|
fn from(s: &String) -> Self {
|
2024-06-30 09:38:39 +00:00
|
|
|
OperatingSystem::from(s.as_str())
|
2024-04-07 13:36:55 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-06-30 09:38:39 +00:00
|
|
|
impl From<&str> for OperatingSystem {
|
2024-04-07 13:36:55 +00:00
|
|
|
fn from(s: &str) -> Self {
|
|
|
|
match s {
|
2024-06-30 09:38:39 +00:00
|
|
|
"windows" => OperatingSystem::Windows,
|
|
|
|
"linux" => OperatingSystem::Linux,
|
|
|
|
"macos" => OperatingSystem::MacOS,
|
|
|
|
"ios" => OperatingSystem::IOS,
|
|
|
|
"android" => OperatingSystem::Android,
|
|
|
|
_ => OperatingSystem::Unknown,
|
2024-04-07 13:36:55 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2024-06-30 09:38:39 +00:00
|
|
|
|
|
|
|
pub fn get_operating_system() -> OperatingSystem {
|
|
|
|
cfg_if::cfg_if! {
|
|
|
|
if #[cfg(target_os = "android")] {
|
|
|
|
OperatingSystem::Android
|
|
|
|
} else if #[cfg(target_os = "ios")] {
|
|
|
|
OperatingSystem::IOS
|
|
|
|
} else if #[cfg(target_os = "macos")] {
|
|
|
|
OperatingSystem::MacOS
|
|
|
|
} else if #[cfg(target_os = "windows")] {
|
|
|
|
OperatingSystem::Windows
|
|
|
|
} else if #[cfg(target_os = "linux")] {
|
|
|
|
OperatingSystem::Linux
|
|
|
|
} else {
|
|
|
|
OperatingSystem::Unknown
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|