From 371ab5e87683c5da8a3686d2c106e7705767c5bb Mon Sep 17 00:00:00 2001 From: NotAShelf Date: Mon, 9 Dec 2024 17:29:32 +0300 Subject: [PATCH] faster release parsing Around 20% faster when you think about it, but results vary becaus of hardware race conditions. --- src/release.rs | 18 ++++++++++-------- 1 file changed, 10 insertions(+), 8 deletions(-) diff --git a/src/release.rs b/src/release.rs index 7600d0e..3f38977 100644 --- a/src/release.rs +++ b/src/release.rs @@ -2,7 +2,7 @@ use color_eyre::Result; use nix::sys::utsname::UtsName; use std::{ fs::File, - io::{self, Read}, + io::{self, BufRead, BufReader}, }; pub fn get_system_info(utsname: &UtsName) -> nix::Result { @@ -15,13 +15,15 @@ pub fn get_system_info(utsname: &UtsName) -> nix::Result { } pub fn get_os_pretty_name() -> Result { - let mut os_release_content = String::with_capacity(1024); - File::open("/etc/os-release")?.read_to_string(&mut os_release_content)?; + let file = File::open("/etc/os-release")?; + let reader = BufReader::new(file); - let pretty_name = os_release_content - .lines() - .find(|line| line.starts_with("PRETTY_NAME=")) - .map(|line| line.trim_start_matches("PRETTY_NAME=").trim_matches('"')); + for line in reader.lines() { + let line = line?; + if let Some(pretty_name) = line.strip_prefix("PRETTY_NAME=") { + return Ok(pretty_name.trim_matches('"').to_string()); + } + } - Ok(pretty_name.unwrap_or("Unknown").to_string()) + Ok("Unknown".to_string()) }