Merge pull request #28 from jonathandturner/split

Add split command
This commit is contained in:
Jonathan Turner 2019-05-24 18:21:40 -07:00 committed by GitHub
commit 8ffc8310bf
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 37 additions and 0 deletions

View file

@ -60,6 +60,7 @@ pub async fn cli() -> Result<(), Box<Error>> {
("skip", Arc::new(skip::skip)),
("first", Arc::new(take::take)),
("select", Arc::new(select::select)),
("split", Arc::new(split::split)),
("reject", Arc::new(reject::reject)),
("to-array", Arc::new(to_array::to_array)),
("where", Arc::new(where_::r#where)),

View file

@ -8,6 +8,7 @@ crate mod reject;
crate mod select;
crate mod skip;
crate mod sort_by;
crate mod split;
crate mod take;
crate mod to_array;
crate mod view;

35
src/commands/split.rs Normal file
View file

@ -0,0 +1,35 @@
use crate::errors::ShellError;
use crate::object::Value;
use crate::prelude::*;
// TODO: "Amount remaining" wrapper
pub fn split(args: CommandArgs) -> Result<OutputStream, ShellError> {
//let splitter = args.args[0].as_string()?;
let input = args.input;
let args = args.args;
Ok(input
.map(move |v| match v {
Value::Primitive(Primitive::String(s)) => {
let splitter = args[0].as_string().unwrap();
let split_result: Vec<_> = s.split(&splitter).filter(|s| s.trim() != "").collect();
if split_result.len() == (args.len() - 1) {
let mut dict = crate::object::Dictionary::default();
for (k, v) in split_result.iter().zip(args.iter().skip(1)) {
dict.add(v.as_string().unwrap(), Value::Primitive(Primitive::String(k.to_string())));
}
ReturnValue::Value(Value::Object(dict))
} else {
let mut dict = crate::object::Dictionary::default();
for k in args.iter().skip(1) {
dict.add(k.as_string().unwrap().trim(), Value::Primitive(Primitive::String("".to_string())));
}
ReturnValue::Value(Value::Object(dict))
}
}
_ => ReturnValue::Value(Value::Object(crate::object::Dictionary::default())),
})
.boxed())
}