nushell/src/format/entries.rs

48 lines
1.1 KiB
Rust
Raw Normal View History

2019-05-10 18:59:12 +02:00
use crate::format::RenderView;
2019-05-15 18:12:38 +02:00
use crate::prelude::*;
2019-05-10 18:59:12 +02:00
use derive_new::new;
// An entries list is printed like this:
//
// name : ...
// name2 : ...
// another_name : ...
#[derive(new)]
pub struct EntriesView {
2019-07-03 19:37:09 +02:00
entries: Vec<(String, String)>,
2019-05-10 18:59:12 +02:00
}
2019-05-16 00:23:36 +02:00
impl EntriesView {
pub(crate) fn from_value(value: &Value) -> EntriesView {
2019-05-16 00:23:36 +02:00
let descs = value.data_descriptors();
let mut entries = vec![];
for desc in descs {
let value = value.get_data(&desc);
2019-11-04 16:47:03 +01:00
let formatted_value = value.borrow().format_leaf().plain_string(75);
2019-05-16 00:23:36 +02:00
2019-07-03 19:37:09 +02:00
entries.push((desc.clone(), formatted_value))
2019-05-16 00:23:36 +02:00
}
EntriesView::new(entries)
}
}
2019-05-10 18:59:12 +02:00
impl RenderView for EntriesView {
fn render_view(&self, _host: &mut dyn Host) -> Result<(), ShellError> {
2019-05-10 18:59:12 +02:00
if self.entries.len() == 0 {
return Ok(());
2019-05-10 18:59:12 +02:00
}
2019-07-03 19:37:09 +02:00
let max_name_size: usize = self.entries.iter().map(|(n, _)| n.len()).max().unwrap();
for (name, value) in &self.entries {
2019-11-04 16:47:03 +01:00
outln!("{:width$} : {}", name, value, width = max_name_size)
}
Ok(())
2019-05-10 18:59:12 +02:00
}
}