Wire hex viewing into a few more places (#572)

This commit is contained in:
JT 2021-12-25 05:15:01 +11:00 committed by GitHub
parent 3522bead97
commit 1efae6876d
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 35 additions and 17 deletions

View file

@ -97,25 +97,30 @@ fn into_binary(
let head = call.head; let head = call.head;
let column_paths: Vec<CellPath> = call.rest(engine_state, stack, 0)?; let column_paths: Vec<CellPath> = call.rest(engine_state, stack, 0)?;
input.map( match input {
move |v| { PipelineData::ByteStream(..) => Ok(input),
if column_paths.is_empty() { _ => input.map(
action(&v, head) move |v| {
} else { if column_paths.is_empty() {
let mut ret = v; action(&v, head)
for path in &column_paths { } else {
let r = let mut ret = v;
ret.update_cell_path(&path.members, Box::new(move |old| action(old, head))); for path in &column_paths {
if let Err(error) = r { let r = ret.update_cell_path(
return Value::Error { error }; &path.members,
Box::new(move |old| action(old, head)),
);
if let Err(error) = r {
return Value::Error { error };
}
} }
}
ret ret
} }
}, },
engine_state.ctrlc.clone(), engine_state.ctrlc.clone(),
) ),
}
} }
fn int_to_endian(n: i64) -> Vec<u8> { fn int_to_endian(n: i64) -> Vec<u8> {

View file

@ -75,6 +75,19 @@ impl Command for Table {
head, head,
None, None,
)), )),
PipelineData::Value(Value::Binary { val, .. }, ..) => Ok(PipelineData::StringStream(
StringStream::from_stream(
vec![Ok(if val.iter().all(|x| x.is_ascii()) {
format!("{}", String::from_utf8_lossy(&val))
} else {
format!("{}\n", nu_pretty_hex::pretty_hex(&val))
})]
.into_iter(),
ctrlc,
),
head,
None,
)),
PipelineData::Value(Value::List { vals, .. }, ..) => { PipelineData::Value(Value::List { vals, .. }, ..) => {
let table = convert_to_table(row_offset, &vals, ctrlc, &config, call.head)?; let table = convert_to_table(row_offset, &vals, ctrlc, &config, call.head)?;