use version::OsVersion;
pub mod os;
#[derive(Clone, Debug, PartialEq, Eq)]
pub enum OsMeta {
#[cfg(target_os = "macos")]
MacOs {
release: Option<os::OsRelease>
},
#[cfg(target_os = "windows")]
Windows {
release: Option<os::OsRelease>
},
#[cfg(target_os = "linux")]
Ubuntu {
release: Option<os::ubuntu::OsRelease>
},
#[cfg(target_os = "linux")]
UnknownLinux {},
}
#[derive(Clone, Debug, PartialEq, Eq)]
pub struct OsInfo {
pub meta: OsMeta,
pub version: Option<OsVersion>,
}
impl OsInfo {
#[cfg(target_os = "macos")]
fn _get() -> OsInfo {
let version = OsVersion::get();
let release = version.and_then(os::OsRelease::new);
OsInfo {
meta: OsMeta::MacOs {
release,
},
version,
}
}
#[cfg(target_os = "windows")]
fn _get() -> OsInfo {
let version = OsVersion::get();
let release = version.and_then(os::OsRelease::new);
OsInfo {
meta: OsMeta::Windows {
release,
},
version,
}
}
#[cfg(target_os = "linux")]
fn _get() -> OsInfo {
let version = OsVersion::get();
OsInfo {
meta: OsMeta::UnknownLinux {},
version,
}
}
pub fn get() -> OsInfo {
OsInfo::_get()
}
pub fn release_name_str(&self) -> Option<&'static str> {
#[cfg(target_os = "linux")]
match self.meta {
OsMeta::Ubuntu { release, .. } => release.map(Into::into),
OsMeta::UnknownLinux { .. } => None,
}
#[cfg(not(target_os = "linux"))]
match self.meta {
#[cfg(target_os = "macos")]
OsMeta::MacOs { release, .. } => release.map(Into::into),
#[cfg(target_os = "windows")]
OsMeta::Windows { release, .. } => release.map(Into::into),
}
}
}
#[cfg(test)]
mod tests {
use super::*;
#[test]
fn get_os_info() {
let info = OsInfo::get();
#[cfg(target_os = "macos")]
{
assert!(info.version.is_some());
match info.meta {
OsMeta::MacOs { release, .. } => {
assert!(release.is_some());
},
}
}
}
}