forked from extern/nushell
Merge pull request #611 from jonathandturner/autoview_plugin
Protect autoview against missing plugins
This commit is contained in:
commit
8be14a891d
@ -43,17 +43,36 @@ pub fn autoview(
|
|||||||
..
|
..
|
||||||
} = input[0usize]
|
} = input[0usize]
|
||||||
{
|
{
|
||||||
let binary = context.expect_command("binaryview");
|
let binary = context.get_command("binaryview");
|
||||||
|
if let Some(binary) = binary {
|
||||||
let result = binary.run(raw.with_input(input), &context.commands);
|
let result = binary.run(raw.with_input(input), &context.commands);
|
||||||
result.collect::<Vec<_>>().await;
|
result.collect::<Vec<_>>().await;
|
||||||
|
} else {
|
||||||
|
for i in input {
|
||||||
|
match i.item {
|
||||||
|
Value::Binary(b) => {
|
||||||
|
use pretty_hex::*;
|
||||||
|
println!("{:?}", b.hex_dump());
|
||||||
|
}
|
||||||
|
_ => {}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
} else if is_single_text_value(&input) {
|
} else if is_single_text_value(&input) {
|
||||||
let text = context.expect_command("textview");
|
let text = context.get_command("textview");
|
||||||
|
if let Some(text) = text {
|
||||||
let result = text.run(raw.with_input(input), &context.commands);
|
let result = text.run(raw.with_input(input), &context.commands);
|
||||||
result.collect::<Vec<_>>().await;
|
result.collect::<Vec<_>>().await;
|
||||||
} else if equal_shapes(&input) {
|
} else {
|
||||||
let table = context.expect_command("table");
|
for i in input {
|
||||||
let result = table.run(raw.with_input(input), &context.commands);
|
match i.item {
|
||||||
result.collect::<Vec<_>>().await;
|
Value::Primitive(Primitive::String(s)) => {
|
||||||
|
println!("{}", s);
|
||||||
|
}
|
||||||
|
_ => {}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
let table = context.expect_command("table");
|
let table = context.expect_command("table");
|
||||||
let result = table.run(raw.with_input(input), &context.commands);
|
let result = table.run(raw.with_input(input), &context.commands);
|
||||||
@ -63,25 +82,6 @@ pub fn autoview(
|
|||||||
}))
|
}))
|
||||||
}
|
}
|
||||||
|
|
||||||
fn equal_shapes(input: &Vec<Tagged<Value>>) -> bool {
|
|
||||||
let mut items = input.iter();
|
|
||||||
|
|
||||||
let item = match items.next() {
|
|
||||||
Some(item) => item,
|
|
||||||
None => return false,
|
|
||||||
};
|
|
||||||
|
|
||||||
let desc = item.data_descriptors();
|
|
||||||
|
|
||||||
for item in items {
|
|
||||||
if desc != item.data_descriptors() {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
true
|
|
||||||
}
|
|
||||||
|
|
||||||
fn is_single_text_value(input: &Vec<Tagged<Value>>) -> bool {
|
fn is_single_text_value(input: &Vec<Tagged<Value>>) -> bool {
|
||||||
if input.len() != 1 {
|
if input.len() != 1 {
|
||||||
return false;
|
return false;
|
||||||
|
@ -236,6 +236,10 @@ impl RunnableContext {
|
|||||||
.get_command(name)
|
.get_command(name)
|
||||||
.expect(&format!("Expected command {}", name))
|
.expect(&format!("Expected command {}", name))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn get_command(&self, name: &str) -> Option<Arc<Command>> {
|
||||||
|
self.commands.get_command(name)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub struct RunnablePerItemArgs<T> {
|
pub struct RunnablePerItemArgs<T> {
|
||||||
|
Loading…
Reference in New Issue
Block a user