mirror of
https://github.com/nushell/nushell
synced 2025-01-16 07:04:09 +00:00
Merge pull request #228 from jonathandturner/sys_unwrap_refactor
Fix unwraps in sys
This commit is contained in:
commit
2e84276d68
1 changed files with 39 additions and 38 deletions
|
@ -31,16 +31,16 @@ async fn cpu(span: Span) -> Option<Spanned<Value>> {
|
||||||
}
|
}
|
||||||
|
|
||||||
async fn mem(span: Span) -> Spanned<Value> {
|
async fn mem(span: Span) -> Spanned<Value> {
|
||||||
let memory = memory::memory().await.unwrap();
|
|
||||||
let swap = memory::swap().await.unwrap();
|
|
||||||
|
|
||||||
let mut dict = SpannedDictBuilder::new(span);
|
let mut dict = SpannedDictBuilder::new(span);
|
||||||
|
|
||||||
|
if let Ok(memory) = memory::memory().await {
|
||||||
dict.insert("total", Value::bytes(memory.total().get()));
|
dict.insert("total", Value::bytes(memory.total().get()));
|
||||||
dict.insert("free", Value::bytes(memory.free().get()));
|
dict.insert("free", Value::bytes(memory.free().get()));
|
||||||
|
}
|
||||||
|
if let Ok(swap) = memory::swap().await {
|
||||||
dict.insert("swap total", Value::bytes(swap.total().get()));
|
dict.insert("swap total", Value::bytes(swap.total().get()));
|
||||||
dict.insert("swap free", Value::bytes(swap.free().get()));
|
dict.insert("swap free", Value::bytes(swap.free().get()));
|
||||||
|
}
|
||||||
|
|
||||||
dict.into_spanned_value()
|
dict.into_spanned_value()
|
||||||
}
|
}
|
||||||
|
@ -78,13 +78,13 @@ async fn host(span: Span) -> Spanned<Value> {
|
||||||
let mut users = heim::host::users();
|
let mut users = heim::host::users();
|
||||||
let mut user_vec = vec![];
|
let mut user_vec = vec![];
|
||||||
while let Some(user) = users.next().await {
|
while let Some(user) = users.next().await {
|
||||||
let user = user.unwrap();
|
if let Ok(user) = user {
|
||||||
|
|
||||||
user_vec.push(Spanned {
|
user_vec.push(Spanned {
|
||||||
item: Value::string(user.username()),
|
item: Value::string(user.username()),
|
||||||
span,
|
span,
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
}
|
||||||
let user_list = Value::List(user_vec);
|
let user_list = Value::List(user_vec);
|
||||||
dict.insert("users", user_list);
|
dict.insert("users", user_list);
|
||||||
|
|
||||||
|
@ -95,11 +95,8 @@ async fn disks(span: Span) -> Value {
|
||||||
let mut output = vec![];
|
let mut output = vec![];
|
||||||
let mut partitions = disk::partitions_physical();
|
let mut partitions = disk::partitions_physical();
|
||||||
while let Some(part) = partitions.next().await {
|
while let Some(part) = partitions.next().await {
|
||||||
let part = part.unwrap();
|
if let Ok(part) = part {
|
||||||
let usage = disk::usage(part.mount_point().to_path_buf()).await.unwrap();
|
|
||||||
|
|
||||||
let mut dict = SpannedDictBuilder::new(span);
|
let mut dict = SpannedDictBuilder::new(span);
|
||||||
|
|
||||||
dict.insert(
|
dict.insert(
|
||||||
"device",
|
"device",
|
||||||
Value::string(
|
Value::string(
|
||||||
|
@ -111,12 +108,14 @@ async fn disks(span: Span) -> Value {
|
||||||
|
|
||||||
dict.insert("type", Value::string(part.file_system().as_str()));
|
dict.insert("type", Value::string(part.file_system().as_str()));
|
||||||
dict.insert("mount", Value::string(part.mount_point().to_string_lossy()));
|
dict.insert("mount", Value::string(part.mount_point().to_string_lossy()));
|
||||||
|
if let Ok(usage) = disk::usage(part.mount_point().to_path_buf()).await {
|
||||||
dict.insert("total", Value::bytes(usage.total().get()));
|
dict.insert("total", Value::bytes(usage.total().get()));
|
||||||
dict.insert("used", Value::bytes(usage.used().get()));
|
dict.insert("used", Value::bytes(usage.used().get()));
|
||||||
dict.insert("free", Value::bytes(usage.free().get()));
|
dict.insert("free", Value::bytes(usage.free().get()));
|
||||||
|
}
|
||||||
output.push(dict.into_spanned_value());
|
output.push(dict.into_spanned_value());
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
Value::List(output)
|
Value::List(output)
|
||||||
}
|
}
|
||||||
|
@ -190,7 +189,9 @@ impl Plugin for Sys {
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
fn begin_filter(&mut self, callinfo: CallInfo) -> Result<Vec<ReturnValue>, ShellError> {
|
fn begin_filter(&mut self, callinfo: CallInfo) -> Result<Vec<ReturnValue>, ShellError> {
|
||||||
Ok(block_on(sysinfo(callinfo.name_span.unwrap()))
|
Ok(block_on(sysinfo(
|
||||||
|
callinfo.name_span.unwrap_or_else(|| Span::unknown()),
|
||||||
|
))
|
||||||
.into_iter()
|
.into_iter()
|
||||||
.map(|x| ReturnSuccess::value(x))
|
.map(|x| ReturnSuccess::value(x))
|
||||||
.collect())
|
.collect())
|
||||||
|
|
Loading…
Reference in a new issue