Introduce get_information
This commit is contained in:
parent
c9ea1f11de
commit
053f352f68
2 changed files with 41 additions and 34 deletions
|
|
@ -582,40 +582,8 @@ pub fn run_command<Message: 'static + std::fmt::Debug + Send, E: Executor>(
|
||||||
},
|
},
|
||||||
command::Action::System(action) => match action {
|
command::Action::System(action) => match action {
|
||||||
system::Action::QueryInformation(tag) => {
|
system::Action::QueryInformation(tag) => {
|
||||||
#[cfg(feature = "sysinfo")]
|
let information =
|
||||||
let information = {
|
crate::system::get_information(graphics_info);
|
||||||
use sysinfo::{
|
|
||||||
ProcessExt, ProcessorExt, System, SystemExt,
|
|
||||||
};
|
|
||||||
let mut system = System::new_all();
|
|
||||||
system.refresh_all();
|
|
||||||
|
|
||||||
let cpu = system.global_processor_info();
|
|
||||||
|
|
||||||
let memory_used = sysinfo::get_current_pid()
|
|
||||||
.and_then(|pid| {
|
|
||||||
system.process(pid).ok_or("Process not found")
|
|
||||||
})
|
|
||||||
.and_then(|process| Ok(process.memory()))
|
|
||||||
.ok();
|
|
||||||
|
|
||||||
let information = system::Information {
|
|
||||||
system_name: system.name(),
|
|
||||||
system_kernel: system.kernel_version(),
|
|
||||||
system_version: system.long_os_version(),
|
|
||||||
cpu_brand: cpu.brand().into(),
|
|
||||||
cpu_cores: system.physical_core_count(),
|
|
||||||
memory_total: system.total_memory(),
|
|
||||||
memory_used,
|
|
||||||
graphics_adapter: graphics_info.adapter.clone(),
|
|
||||||
graphics_backend: graphics_info.backend.clone(),
|
|
||||||
};
|
|
||||||
|
|
||||||
Some(information)
|
|
||||||
};
|
|
||||||
|
|
||||||
#[cfg(not(feature = "sysinfo"))]
|
|
||||||
let information = None;
|
|
||||||
|
|
||||||
let message = tag(information);
|
let message = tag(information);
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -2,6 +2,8 @@
|
||||||
use crate::command::{self, Command};
|
use crate::command::{self, Command};
|
||||||
pub use iced_native::system::*;
|
pub use iced_native::system::*;
|
||||||
|
|
||||||
|
use iced_graphics::window;
|
||||||
|
|
||||||
/// Query for available system information.
|
/// Query for available system information.
|
||||||
///
|
///
|
||||||
/// Returns `None` if not using the `sysinfo` feature flag.
|
/// Returns `None` if not using the `sysinfo` feature flag.
|
||||||
|
|
@ -12,3 +14,40 @@ pub fn information<Message>(
|
||||||
Box::new(f),
|
Box::new(f),
|
||||||
)))
|
)))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[cfg(feature = "sysinfo")]
|
||||||
|
pub(crate) fn get_information(
|
||||||
|
graphics_info: &window::GraphicsInformation,
|
||||||
|
) -> Option<Information> {
|
||||||
|
use sysinfo::{ProcessExt, ProcessorExt, System, SystemExt};
|
||||||
|
let mut system = System::new_all();
|
||||||
|
system.refresh_all();
|
||||||
|
|
||||||
|
let cpu = system.global_processor_info();
|
||||||
|
|
||||||
|
let memory_used = sysinfo::get_current_pid()
|
||||||
|
.and_then(|pid| system.process(pid).ok_or("Process not found"))
|
||||||
|
.and_then(|process| Ok(process.memory()))
|
||||||
|
.ok();
|
||||||
|
|
||||||
|
let information = Information {
|
||||||
|
system_name: system.name(),
|
||||||
|
system_kernel: system.kernel_version(),
|
||||||
|
system_version: system.long_os_version(),
|
||||||
|
cpu_brand: cpu.brand().into(),
|
||||||
|
cpu_cores: system.physical_core_count(),
|
||||||
|
memory_total: system.total_memory(),
|
||||||
|
memory_used,
|
||||||
|
graphics_adapter: graphics_info.adapter.clone(),
|
||||||
|
graphics_backend: graphics_info.backend.clone(),
|
||||||
|
};
|
||||||
|
|
||||||
|
Some(information)
|
||||||
|
}
|
||||||
|
|
||||||
|
#[cfg(not(feature = "sysinfo"))]
|
||||||
|
pub(crate) fn get_information(
|
||||||
|
_graphics_info: &window::GraphicsInformation,
|
||||||
|
) -> Option<Information> {
|
||||||
|
None
|
||||||
|
}
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue