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,15 +97,19 @@ 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 {
PipelineData::ByteStream(..) => Ok(input),
_ => input.map(
move |v| { move |v| {
if column_paths.is_empty() { if column_paths.is_empty() {
action(&v, head) action(&v, head)
} else { } else {
let mut ret = v; let mut ret = v;
for path in &column_paths { for path in &column_paths {
let r = let r = ret.update_cell_path(
ret.update_cell_path(&path.members, Box::new(move |old| action(old, head))); &path.members,
Box::new(move |old| action(old, head)),
);
if let Err(error) = r { if let Err(error) = r {
return Value::Error { error }; return Value::Error { error };
} }
@ -115,7 +119,8 @@ fn into_binary(
} }
}, },
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)?;