in below/dump/src/disk.rs [42:137]
fn dump_model(
&self,
ctx: &CommonFieldContext,
model: &model::Model,
output: &mut dyn Write,
round: &mut usize,
comma_flag: bool,
) -> Result<IterExecResult> {
let mut disks: Vec<_> = model
.system
.disks
.iter()
.filter_map(
|(_, model)| match (self.select.as_ref(), self.opts.filter.as_ref()) {
(Some(field_id), Some(filter))
if !filter.is_match(
&model
.query(&field_id)
.map_or("?".to_owned(), |v| v.to_string()),
) =>
{
None
}
_ => Some(model),
},
)
.collect();
if let Some(field_id) = &self.select {
if self.opts.sort {
model::sort_queriables(&mut disks, &field_id, false);
}
if self.opts.rsort {
model::sort_queriables(&mut disks, &field_id, true);
}
if (self.opts.sort || self.opts.rsort) && self.opts.top != 0 {
disks.truncate(self.opts.top as usize);
}
}
let json = self.opts.output_format == Some(OutputFormat::Json);
let mut json_output = json!([]);
disks
.into_iter()
.map(|model| {
match self.opts.output_format {
Some(OutputFormat::Raw) | None => write!(
output,
"{}",
print::dump_raw_indented(
&self.fields,
ctx,
model,
*round,
self.opts.repeat_title,
self.opts.disable_title,
self.opts.raw
)
)?,
Some(OutputFormat::Csv) => write!(
output,
"{}",
print::dump_csv(
&self.fields,
ctx,
model,
*round,
self.opts.disable_title,
self.opts.raw
)
)?,
Some(OutputFormat::KeyVal) => write!(
output,
"{}",
print::dump_kv(&self.fields, ctx, model, self.opts.raw)
)?,
Some(OutputFormat::Json) => {
let par = print::dump_json(&self.fields, ctx, model, self.opts.raw);
json_output.as_array_mut().unwrap().push(par);
}
}
*round += 1;
Ok(())
})
.collect::<Result<Vec<_>>>()?;
match (json, comma_flag) {
(true, true) => write!(output, ",{}", json_output)?,
(true, false) => write!(output, "{}", json_output)?,
_ => write!(output, "\n")?,
};
Ok(IterExecResult::Success)
}