From 81691e07c6c47644f2ff6d33c45bd6822521c421 Mon Sep 17 00:00:00 2001 From: Jonathan Turner Date: Wed, 30 Oct 2019 19:54:06 +1300 Subject: [PATCH 1/2] Add prepend and append commands --- src/cli.rs | 2 ++ src/commands.rs | 4 ++++ src/commands/append.rs | 49 +++++++++++++++++++++++++++++++++++++++++ src/commands/prepend.rs | 49 +++++++++++++++++++++++++++++++++++++++++ tests/tests.rs | 32 +++++++++++++++++++++++++++ 5 files changed, 136 insertions(+) create mode 100644 src/commands/append.rs create mode 100644 src/commands/prepend.rs diff --git a/src/cli.rs b/src/cli.rs index 9661cb320..f46db1052 100644 --- a/src/cli.rs +++ b/src/cli.rs @@ -264,6 +264,8 @@ pub async fn cli() -> Result<(), Box> { whole_stream_command(Lines), whole_stream_command(Reject), whole_stream_command(Reverse), + whole_stream_command(Append), + whole_stream_command(Prepend), whole_stream_command(Trim), whole_stream_command(ToBSON), whole_stream_command(ToCSV), diff --git a/src/commands.rs b/src/commands.rs index c75ca8119..ba69d1e82 100644 --- a/src/commands.rs +++ b/src/commands.rs @@ -1,6 +1,7 @@ #[macro_use] pub(crate) mod macros; +pub(crate) mod append; pub(crate) mod args; pub(crate) mod autoview; pub(crate) mod cd; @@ -45,6 +46,7 @@ pub(crate) mod pick; pub(crate) mod pivot; pub(crate) mod plugin; pub(crate) mod post; +pub(crate) mod prepend; pub(crate) mod prev; pub(crate) mod pwd; pub(crate) mod reject; @@ -79,6 +81,7 @@ pub(crate) use command::{ UnevaluatedCallInfo, WholeStreamCommand, }; +pub(crate) use append::Append; pub(crate) use classified::ClassifiedCommand; pub(crate) use config::Config; pub(crate) use count::Count; @@ -119,6 +122,7 @@ pub(crate) use open::Open; pub(crate) use pick::Pick; pub(crate) use pivot::Pivot; pub(crate) use post::Post; +pub(crate) use prepend::Prepend; pub(crate) use prev::Previous; pub(crate) use pwd::PWD; pub(crate) use reject::Reject; diff --git a/src/commands/append.rs b/src/commands/append.rs new file mode 100644 index 000000000..b8ca7b6e9 --- /dev/null +++ b/src/commands/append.rs @@ -0,0 +1,49 @@ +use crate::commands::WholeStreamCommand; +use crate::errors::ShellError; +use crate::parser::CommandRegistry; +use crate::prelude::*; + +#[derive(Deserialize)] +struct AppendArgs { + row: Tagged, +} + +pub struct Append; + +impl WholeStreamCommand for Append { + fn name(&self) -> &str { + "append" + } + + fn signature(&self) -> Signature { + Signature::build("append").required( + "row value", + SyntaxShape::Any, + "the value of the row to append to the table", + ) + } + + fn usage(&self) -> &str { + "Append the given row to the table" + } + + fn run( + &self, + args: CommandArgs, + registry: &CommandRegistry, + ) -> Result { + args.process(registry, append)?.run() + } +} + +fn append( + AppendArgs { row }: AppendArgs, + RunnableContext { input, .. }: RunnableContext, +) -> Result { + let mut after: VecDeque> = VecDeque::new(); + after.push_back(row); + + Ok(OutputStream::from_input( + input.values.chain(after), + )) +} diff --git a/src/commands/prepend.rs b/src/commands/prepend.rs new file mode 100644 index 000000000..4d9c037f4 --- /dev/null +++ b/src/commands/prepend.rs @@ -0,0 +1,49 @@ +use crate::commands::WholeStreamCommand; +use crate::errors::ShellError; +use crate::parser::CommandRegistry; +use crate::prelude::*; + +#[derive(Deserialize)] +struct PrependArgs { + row: Tagged, +} + +pub struct Prepend; + +impl WholeStreamCommand for Prepend { + fn name(&self) -> &str { + "prepend" + } + + fn signature(&self) -> Signature { + Signature::build("prepend").required( + "row value", + SyntaxShape::Any, + "the value of the row to prepend to the table", + ) + } + + fn usage(&self) -> &str { + "Prepend the given row to the front of the table" + } + + fn run( + &self, + args: CommandArgs, + registry: &CommandRegistry, + ) -> Result { + args.process(registry, prepend)?.run() + } +} + +fn prepend( + PrependArgs { row }: PrependArgs, + RunnableContext { input, .. }: RunnableContext, +) -> Result { + let mut prepend: VecDeque> = VecDeque::new(); + prepend.push_back(row); + + Ok(OutputStream::from_input( + prepend.chain(input.values), + )) +} diff --git a/tests/tests.rs b/tests/tests.rs index 1a739f198..14552a41e 100644 --- a/tests/tests.rs +++ b/tests/tests.rs @@ -72,6 +72,38 @@ fn read_plugin() { assert_eq!(actual, "StupidLongName"); } +#[test] +fn prepend_plugin() { + let actual = nu!( + cwd: "tests/fixtures/formats", h::pipeline( + r#" + open fileA.txt + | lines + | prepend "testme" + | nth 0 + | echo $it + "# + )); + + assert_eq!(actual, "testme"); +} + +#[test] +fn append_plugin() { + let actual = nu!( + cwd: "tests/fixtures/formats", h::pipeline( + r#" + open fileA.txt + | lines + | append "testme" + | nth 3 + | echo $it + "# + )); + + assert_eq!(actual, "testme"); +} + #[test] fn edit_plugin() { let actual = nu!( From a9cd6b4f7afd8617936fd357c408dc4412857821 Mon Sep 17 00:00:00 2001 From: Jonathan Turner Date: Wed, 30 Oct 2019 20:04:39 +1300 Subject: [PATCH 2/2] Format files --- src/commands/append.rs | 4 +--- src/commands/prepend.rs | 4 +--- 2 files changed, 2 insertions(+), 6 deletions(-) diff --git a/src/commands/append.rs b/src/commands/append.rs index b8ca7b6e9..fe22c9065 100644 --- a/src/commands/append.rs +++ b/src/commands/append.rs @@ -43,7 +43,5 @@ fn append( let mut after: VecDeque> = VecDeque::new(); after.push_back(row); - Ok(OutputStream::from_input( - input.values.chain(after), - )) + Ok(OutputStream::from_input(input.values.chain(after))) } diff --git a/src/commands/prepend.rs b/src/commands/prepend.rs index 4d9c037f4..b6fa935b0 100644 --- a/src/commands/prepend.rs +++ b/src/commands/prepend.rs @@ -43,7 +43,5 @@ fn prepend( let mut prepend: VecDeque> = VecDeque::new(); prepend.push_back(row); - Ok(OutputStream::from_input( - prepend.chain(input.values), - )) + Ok(OutputStream::from_input(prepend.chain(input.values))) }