From 0fe889b2d29ed6f49d57ecd15fdcdc0c7907ea1f Mon Sep 17 00:00:00 2001 From: Kenny Kerr Date: Tue, 14 Nov 2023 20:43:53 -0600 Subject: [PATCH] OsVersion --- crates/libs/version/readme.md | 4 +-- crates/libs/version/src/lib.rs | 64 +++++++++++++++++----------------- 2 files changed, 34 insertions(+), 34 deletions(-) diff --git a/crates/libs/version/readme.md b/crates/libs/version/readme.md index 7db251b1d7..0d9d829fd1 100644 --- a/crates/libs/version/readme.md +++ b/crates/libs/version/readme.md @@ -19,13 +19,13 @@ Make use of Windows version information as needed: use windows_version::*; fn main() { - println!("Current version: {:?}", Version::current()); + println!("Current version: {:?}", OsVersion::current()); if is_server() { println!("Running on a Windows Server release."); } - if Version::current() >= Version::new(10, 0, 0, 12345) { + if OsVersion::current() >= OsVersion::new(10, 0, 0, 12345) { println!("Can use a feature available on this version or later.") } } diff --git a/crates/libs/version/src/lib.rs b/crates/libs/version/src/lib.rs index e724596f70..6d8990ed39 100644 --- a/crates/libs/version/src/lib.rs +++ b/crates/libs/version/src/lib.rs @@ -5,7 +5,7 @@ use bindings::*; /// Operating system version information. #[derive(Debug, Copy, Clone, PartialEq, Eq, PartialOrd, Ord)] -pub struct Version { +pub struct OsVersion { /// The major version number of the operating system. pub major: u32, @@ -19,8 +19,8 @@ pub struct Version { pub build: u32, } -impl Version { - /// Creates a new `Version` with the given values. +impl OsVersion { + /// Creates a new `OsVersion` with the given values. pub const fn new(major: u32, minor: u32, pack: u32, build: u32) -> Self { Self { major, @@ -41,7 +41,7 @@ impl Version { RtlGetVersion(&mut info as *mut _ as *mut _); - Version { + OsVersion { major: info.dwMajorVersion, minor: info.dwMinorVersion, pack: info.wServicePackMajor as u32, @@ -72,45 +72,45 @@ pub fn is_server() -> bool { #[cfg(test)] mod test { - use super::Version; + use super::OsVersion; use std::sync::RwLock; - static TEST_CURRENT: RwLock = RwLock::new(Version::new(0, 0, 0, 0)); + static TEST_CURRENT: RwLock = RwLock::new(OsVersion::new(0, 0, 0, 0)); - pub fn test_current() -> Version { + pub fn test_current() -> OsVersion { *TEST_CURRENT.read().unwrap() } - fn set_current(version: Version) { + fn set_current(version: OsVersion) { *TEST_CURRENT.write().unwrap() = version; } #[test] fn test() { - assert_eq!(Version::current(), Version::new(0, 0, 0, 0)); - - set_current(Version::new(1, 2, 3, 4)); - assert_eq!(Version::current(), Version::new(1, 2, 3, 4)); - - set_current(Version::new(10, 0, 0, 0)); - assert!(Version::current() >= Version::new(9, 0, 0, 0)); - assert!(Version::current() >= Version::new(10, 0, 0, 0)); - assert!(!(Version::current() >= Version::new(11, 0, 0, 0))); - - set_current(Version::new(10, 100, 0, 0)); - assert!(Version::current() >= Version::new(10, 99, 0, 0)); - assert!(Version::current() >= Version::new(10, 100, 0, 0)); - assert!(!(Version::current() >= Version::new(10, 101, 0, 0))); - - set_current(Version::new(10, 100, 1000, 0)); - assert!(Version::current() >= Version::new(10, 100, 999, 0)); - assert!(Version::current() >= Version::new(10, 100, 1000, 0)); - assert!(!(Version::current() >= Version::new(10, 100, 1001, 0))); - - set_current(Version::new(10, 100, 1_000, 10_000)); - assert!(Version::current() >= Version::new(10, 100, 1_000, 9_999)); - assert!(Version::current() >= Version::new(10, 100, 1_000, 10_000)); - assert!(!(Version::current() >= Version::new(10, 100, 1_000, 10_001))); + assert_eq!(OsVersion::current(), OsVersion::new(0, 0, 0, 0)); + + set_current(OsVersion::new(1, 2, 3, 4)); + assert_eq!(OsVersion::current(), OsVersion::new(1, 2, 3, 4)); + + set_current(OsVersion::new(10, 0, 0, 0)); + assert!(OsVersion::current() >= OsVersion::new(9, 0, 0, 0)); + assert!(OsVersion::current() >= OsVersion::new(10, 0, 0, 0)); + assert!(!(OsVersion::current() >= OsVersion::new(11, 0, 0, 0))); + + set_current(OsVersion::new(10, 100, 0, 0)); + assert!(OsVersion::current() >= OsVersion::new(10, 99, 0, 0)); + assert!(OsVersion::current() >= OsVersion::new(10, 100, 0, 0)); + assert!(!(OsVersion::current() >= OsVersion::new(10, 101, 0, 0))); + + set_current(OsVersion::new(10, 100, 1000, 0)); + assert!(OsVersion::current() >= OsVersion::new(10, 100, 999, 0)); + assert!(OsVersion::current() >= OsVersion::new(10, 100, 1000, 0)); + assert!(!(OsVersion::current() >= OsVersion::new(10, 100, 1001, 0))); + + set_current(OsVersion::new(10, 100, 1_000, 10_000)); + assert!(OsVersion::current() >= OsVersion::new(10, 100, 1_000, 9_999)); + assert!(OsVersion::current() >= OsVersion::new(10, 100, 1_000, 10_000)); + assert!(!(OsVersion::current() >= OsVersion::new(10, 100, 1_000, 10_001))); } #[test]