Support binary save

This commit is contained in:
Patrick Meredith 2019-09-03 21:50:23 -04:00
parent c6c4d4ddb1
commit ab48d3a3f2
4 changed files with 67 additions and 19 deletions

View File

@ -496,6 +496,10 @@ pub trait WholeStreamCommand: Send + Sync {
args: CommandArgs,
registry: &registry::CommandRegistry,
) -> Result<OutputStream, ShellError>;
fn is_binary(&self) -> bool {
false
}
}
pub trait PerItemCommand: Send + Sync {
@ -521,6 +525,10 @@ pub trait PerItemCommand: Send + Sync {
raw_args: &RawCommandArgs,
input: Tagged<Value>,
) -> Result<OutputStream, ShellError>;
fn is_binary(&self) -> bool {
false
}
}
pub enum Command {
@ -608,6 +616,13 @@ impl Command {
}
}
}
pub fn is_binary(&self) -> bool {
match self {
Command::WholeStream(command) => command.is_binary(),
Command::PerItem(command) => command.is_binary(),
}
}
}
pub struct FnFilterCommand {

View File

@ -96,7 +96,7 @@ fn save(
}
}
let content = if !save_raw {
let content : Result<Vec<u8>, ShellError> = if !save_raw {
if let Some(extension) = full_path.extension() {
let command_name = format!("to-{}", extension.to_str().unwrap());
if let Some(converter) = registry.get_command(&command_name) {
@ -116,6 +116,26 @@ fn save(
};
let mut result = converter.run(new_args.with_input(input), &registry);
let result_vec: Vec<Result<ReturnSuccess, ShellError>> = result.drain_vec().await;
if converter.is_binary() {
let mut result_binary : Vec<u8> = Vec::new();
for res in result_vec {
match res {
Ok(ReturnSuccess::Value(Tagged { item: Value::Binary(b), .. })) => {
for u in b.into_iter() {
result_binary.push(u);
}
}
_ => {
yield Err(ShellError::labeled_error(
"Save could not successfully save",
"unexpected data during binary save",
name_span,
));
},
}
}
Ok(result_binary)
} else {
let mut result_string = String::new();
for res in result_vec {
match res {
@ -125,30 +145,13 @@ fn save(
_ => {
yield Err(ShellError::labeled_error(
"Save could not successfully save",
"unexpected data during save",
"unexpected data during text save",
name_span,
));
},
}
}
Ok(result_string)
} else {
let mut result_string = String::new();
for res in input {
match res {
Tagged { item: Value::Primitive(Primitive::String(s)), .. } => {
result_string.push_str(&s);
}
_ => {
yield Err(ShellError::labeled_error(
"Save could not successfully save",
"unexpected data during save",
name_span,
));
},
}
}
Ok(result_string)
Ok(result_string.into_bytes())
}
} else {
let mut result_string = String::new();
@ -166,10 +169,28 @@ fn save(
},
}
}
Ok(result_string)
Ok(result_string.into_bytes())
}
} else {
string_from(&input)
let mut result_string = String::new();
for res in input {
match res {
Tagged { item: Value::Primitive(Primitive::String(s)), .. } => {
result_string.push_str(&s);
}
_ => {
yield Err(ShellError::labeled_error(
"Save could not successfully save",
"unexpected data during save",
name_span,
));
},
}
}
Ok(result_string.into_bytes())
}
} else {
Ok(string_from(&input).into_bytes())
};
match content {
@ -185,7 +206,7 @@ fn save(
Ok(OutputStream::new(stream))
}
fn string_from(input: &Vec<Tagged<Value>>) -> Result<String, ShellError> {
fn string_from(input: &Vec<Tagged<Value>>) -> String {
let mut save_data = String::new();
if input.len() > 0 {
@ -202,5 +223,5 @@ fn string_from(input: &Vec<Tagged<Value>>) -> Result<String, ShellError> {
}
}
Ok(save_data)
save_data
}

View File

@ -26,6 +26,10 @@ impl WholeStreamCommand for ToBSON {
) -> Result<OutputStream, ShellError> {
to_bson(args, registry)
}
fn is_binary(&self) -> bool {
true
}
}
pub fn value_to_bson_value(v: &Tagged<Value>) -> Result<Bson, ShellError> {

View File

@ -27,6 +27,10 @@ impl WholeStreamCommand for ToSQLite {
) -> Result<OutputStream, ShellError> {
to_sqlite(args, registry)
}
fn is_binary(&self) -> bool {
true
}
}
pub struct ToDB;
@ -51,6 +55,10 @@ impl WholeStreamCommand for ToDB {
) -> Result<OutputStream, ShellError> {
to_sqlite(args, registry)
}
fn is_binary(&self) -> bool {
true
}
}
fn comma_concat(acc: String, current: String) -> String {